Struct BinaryTree

Source
pub struct BinaryTree<T> {
    pub root: TreeNode<T>,
    pub left: Option<Box<BinaryTree<T>>>,
    pub right: Option<Box<BinaryTree<T>>>,
}
Expand description

A BinaryTree data structure that contains a TreeNode and two optional child nodes (left and right)

This structure represents a binary tree where each node contains a TreeNode value and two child nodes, left and right, which are either Some(Box<BinaryTree<T>>), or None if the node has no children.

Fields§

§root: TreeNode<T>

The root of the BinaryTree

§left: Option<Box<BinaryTree<T>>>

The left child of the BinaryTree, or None if there is no left child

§right: Option<Box<BinaryTree<T>>>

The right child of the BinaryTree, or None if there is no right child

Implementations§

Source§

impl<T> BinaryTree<T>

Source

pub fn new( root: TreeNode<T>, left: Option<Box<BinaryTree<T>>>, right: Option<Box<BinaryTree<T>>>, ) -> Self

Creates a new BinaryTree with the given node, left child, and right child.

§Parameters
  • root: A TreeNode object that represents the topmost node of this BinaryTree
  • left: An optional BinaryTree Box pointer that points to the left child of this BinaryTree, or None if no left child exists
  • right: An optional BinaryTree Box pointer that points to the right child of this BinaryTree, or None if no right child exists
§Returns
  • A new instance of a BinaryTree containing the given root node, left child, and right child
§Examples
use dsa::data_structures::tree::{BinaryTree, TreeNode};
let tree = BinaryTree::new(
    TreeNode::new(1), 
    Some(Box::new(BinaryTree::new(TreeNode::new(2), None, None))),
    Some(Box::new(BinaryTree::new(TreeNode::new(3), None, None)))
);

Auto Trait Implementations§

§

impl<T> Freeze for BinaryTree<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for BinaryTree<T>
where T: RefUnwindSafe,

§

impl<T> Send for BinaryTree<T>
where T: Send,

§

impl<T> Sync for BinaryTree<T>
where T: Sync,

§

impl<T> Unpin for BinaryTree<T>
where T: Unpin,

§

impl<T> UnwindSafe for BinaryTree<T>
where T: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.