zoukankan      html  css  js  c++  java
  • 二叉搜索树 Rust实现

    二叉搜索树

    • 二叉搜索树是一颗二叉树
    • 每个节点应该包含三个属性 left, right, p, 根节点pNIL
    • 设x是二叉搜索树的一个节点, y是x左子树的一个节点, 那么y.key <= x.key, 若y是x右子树的一个节点, 那么y.key >= x.key

    遍历

    遍历分前中后, 以根节点的遍历顺序而划分

    之前写过一篇二叉搜索树的, 用C语言实现, 可以参考一下C语言实现
    感受一下区别

    以下是代码, 来源于RustPrimer

    type TreeNode<K, V> = Option<Box<Node<K, V>>>;
    #[derive(Debug)]
    struct Node<K, V: std::fmt::Display> {
        left: TreeNode<K, V>,
        right: TreeNode<K, V>,
        key: K,
        value: V,
    }
    trait BinaryTree<K, V> {
        fn pre_order(&self);
        fn in_order(&self);
        fn pos_order(&self);
    }
    trait BinarySearchTree<K: PartialOrd, V>: BinaryTree<K, V> {
        fn insert(&mut self, key: K, value: V);
    }
    impl<K, V: std::fmt::Display> Node<K, V> {
        fn new(key: K, value: V) -> Self {
            Node {
                left: None,
                right: None,
                value: value,
                key: key,
            }
        }
    }
    impl<K: PartialOrd, V: std::fmt::Display> BinarySearchTree<K, V> for Node<K, V> {
        fn insert(&mut self, key: K, value: V) {
            if self.key < key {
                if let Some(ref mut right) = self.right {
                    right.insert(key, value);
                } else {
                    self.right = Some(Box::new(Node::new(key, value)));
                }
            } else {
                if let Some(ref mut left) = self.left {
                    left.insert(key, value);
                } else {
                    self.left = Some(Box::new(Node::new(key, value)));
                }
            }
        }
    }
    impl<K, V: std::fmt::Display> BinaryTree<K, V> for Node<K, V> {
        fn pre_order(&self) {
            println!("{}", self.value);
    
            if let Some(ref left) = self.left {
                left.pre_order();
            }
            if let Some(ref right) = self.right {
                right.pre_order();
            }
        }
    
        fn in_order(&self) {
            if let Some(ref left) = self.left {
                left.in_order();
            }
            println!("{}", self.value);
            if let Some(ref right) = self.right {
                right.in_order();
            }
        }
        fn pos_order(&self) {
            if let Some(ref left) = self.left {
                left.pos_order();
            }
            if let Some(ref right) = self.right {
                right.pos_order();
            }
            println!("{}", self.value);
        }
    }
    
    type BST<K, V> = Node<K, V>;
    
    fn test_insert() {
        let mut root = BST::<i32, i32>::new(3, 4);
        root.insert(2, 3);
        root.insert(4, 6);
        root.insert(5, 5);
        root.insert(6, 6);
        root.insert(1, 8);
        if let Some(ref left) = root.left {
            assert_eq!(left.value, 3);
        }
    
        if let Some(ref right) = root.right {
            assert_eq!(right.value, 6);
            if let Some(ref right) = right.right {
                assert_eq!(right.value, 5);
            }
        }
        println!("Pre Order traversal");
        root.pre_order();
        println!("In Order traversal");
        root.in_order();
        println!("Pos Order traversal");
        root.pos_order();
    }
    
    fn main() {
        test_insert();
    }
    
    
  • 相关阅读:
    BZOJ 3513: [MUTC2013]idiots(fft)
    BZOJ 2194: 快速傅立叶之二(fft)
    BZOJ 3779: 重组病毒(线段树+lct+树剖)
    LUOGU P3723 [AH2017/HNOI2017]礼物 (fft)
    CF 622F (拉格朗日插值)
    LUOGU P4781 【模板】拉格朗日插值
    bzoj 4184 shallot——线段树分治+线性基
    51nod 1673 树有几多愁——虚树+状压DP
    bzoj 3611(洛谷 4103) [Heoi2014]大工程——虚树
    bzoj 2286(洛谷 2495) [Sdoi2011]消耗战——虚树
  • 原文地址:https://www.cnblogs.com/kwebi/p/9649462.html
Copyright © 2011-2022 走看看