Struct ds_bst::BinarySearchTree[][src]

pub struct BinarySearchTree<T> { /* fields omitted */ }

Implements a Binary Search Tree. This is a recursive data structure and left and right refers to sub trees.

Tree is an entry point for the root node. It’s much simpler to create a tree form a vector.

Example

Implements binary search tree with traversal (inorder)

use ds_bst::BinarySearchTree;

let mut root = BinarySearchTree::from(vec![1,2,3,4,5,6,7,8,9]);
root.insert(10);
let ordered: Vec<_> = root.inorder();

let mut root2 = BinarySearchTree::new(5);
root2.insert(1);
root2.insert(6);

Implementations

impl<T: PartialOrd + Copy> BinarySearchTree<T>[src]

pub fn new(v: T) -> BinarySearchTree<T>[src]

Contructor creates BinarySearchTree from one element

pub fn from(data: Vec<T>) -> BinarySearchTree<T>[src]

Delegates tree building to BinarySearchTree::build_recursive() This sorts vector input and pass splice to tree builder.

pub fn build_recursive(
    data: &[T],
    start: isize,
    end: isize
) -> Option<Box<BinarySearchTree<T>>>
[src]

Recursively builds tree maintaining BST properties. Uses O(n) time.

pub fn inorder(&self) -> Vec<T>[src]

Inorder traverse tree which yields elements in sorted order. Uses O(n) time. TODO: Implement Iterator

pub fn preorder(&self) -> Vec<T>[src]

Traverse tree in preorder. Uses O(n) time. TODO: Implement using iterator

pub fn insert(&mut self, val: T)[src]

Inserts an element in a tree. Uses O(n) time.

pub fn exists(&self, val: T) -> bool[src]

Checks if element exists in a tree. Uses O(n) time.

pub fn find_min(&self) -> T[src]

Finds minimum element in a tree. Uses O(n) time.

pub fn find_max(&self) -> T[src]

Finds maximum element in a tree. Uses O(n) time.

Auto Trait Implementations

impl<T> RefUnwindSafe for BinarySearchTree<T> where
    T: RefUnwindSafe

impl<T> Send for BinarySearchTree<T> where
    T: Send

impl<T> Sync for BinarySearchTree<T> where
    T: Sync

impl<T> Unpin for BinarySearchTree<T> where
    T: Unpin

impl<T> UnwindSafe for BinarySearchTree<T> where
    T: UnwindSafe

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.