zoukankan      html  css  js  c++  java
  • 树的遍历

    本文为博主原创,未经允许不得转载:

      1.树结构特点

    import java.util.Stack;
    
    public class BST<E extends Comparable<E>> {
    
        private class Node {
            public E e;
            public Node left, right;
    
            public Node(E e) {
                this.e = e;
                left = null;
                right = null;
            }
        }
    
        private Node root;
        private int size;
    
        public BST(){
            root = null;
            size = 0;
        }
    
        public int size(){
            return size;
        }
    
        public boolean isEmpty(){
            return size == 0;
        }
    
        // 向二分搜索树中添加新的元素e
        public void add(E e){
            root = add(root, e);
        }
    
        // 向以node为根的二分搜索树中插入元素e,递归算法
        // 返回插入新节点后二分搜索树的根
        private Node add(Node node, E e){
            if(node == null){
                size ++;
                return new Node(e);
            }
    
            if(e.compareTo(node.e) < 0)
                node.left = add(node.left, e);
            else if(e.compareTo(node.e) > 0)
                node.right = add(node.right, e);
    
            return node;
        }
    
        // 看二分搜索树中是否包含元素e
        public boolean contains(E e){
            return contains(root, e);
        }
    
        // 看以node为根的二分搜索树中是否包含元素e, 递归算法
        private boolean contains(Node node, E e){
    
            if(node == null)
                return false;
    
            if(e.compareTo(node.e) == 0)
                return true;
            else if(e.compareTo(node.e) < 0)
                return contains(node.left, e);
            else // e.compareTo(node.e) > 0
                return contains(node.right, e);
        }
    
        // 二分搜索树的前序遍历
        public void preOrder(){
            preOrder(root);
        }
    
        // 前序遍历以node为根的二分搜索树, 递归算法
        private void preOrder(Node node){
            if(node == null)
                return;
    
            System.out.println(node.e);
            preOrder(node.left);
            preOrder(node.right);
        }
    
        // 二分搜索树的中序遍历
        public void inOrder(){
            inOrder(root);
        }
    
        // 中序遍历以node为根的二分搜索树, 递归算法
        private void inOrder(Node node){
            if(node == null)
                return;
    
            inOrder(node.left);
            System.out.println(node.e);
            inOrder(node.right);
        }
    
        // 二分搜索树的后序遍历
        public void postOrder(){
            postOrder(root);
        }
    
        // 后序遍历以node为根的二分搜索树, 递归算法
        private void postOrder(Node node){
            if(node == null)
                return;
    
            postOrder(node.left);
            postOrder(node.right);
            System.out.println(node.e);
        }
    
        @Override
        public String toString(){
            StringBuilder res = new StringBuilder();
            generateString(root, 0, res);
            return res.toString();
        }
    
        // 生成以node为根节点,深度为depth的描述二叉树的字符串
        private void generateString(Node node, int depth, StringBuilder res){
    
            if(node == null){
                res.append(generateDepthString(depth) + "null
    ");
                return;
            }
    
            res.append(generateDepthString(depth) + node.e + "
    ");
            generateString(node.left, depth + 1, res);
            generateString(node.right, depth + 1, res);
        }
    
        private String generateDepthString(int depth){
            StringBuilder res = new StringBuilder();
            for(int i = 0 ; i < depth ; i ++)
                res.append("--");
            return res.toString();
        }
    }

      2. 前序遍历

      3. 中序便利

      4.后序遍历

    public class Main {
    
        public static void main(String[] args) {
    
            BST<Integer> bst = new BST<>();
            int[] nums = {5, 3, 6, 8, 4, 2};
            for(int num: nums)
                bst.add(num);
    
            /////////////////
            //      5      //
            //    /       //
            //   3    6    //
            //  /        //
            // 2  4     8  //
            /////////////////
            bst.preOrder();
            System.out.println();
    
            bst.inOrder();
            System.out.println();
    
            bst.postOrder();
            System.out.println();
        }
    }

     

    https://blog.csdn.net/u013834525/article/details/80421684

  • 相关阅读:
    如何在调试PHP代码时不显示错误信息
    如何实现网页组件的随意拖拽
    如何做一个简易的HTML代码编辑器
    如何在网页中动态显示时间
    Luogu2577 | [ZJOI2005]午餐 (贪心+DP)
    Luogu2345 | 奶牛集会 (树状数组)
    解决NahimicSvc32.exe与bilibili直播姬的音频不兼容的问题
    STL函数 lower_bound 和 upper_bound 在算法竞赛中的用法
    电子取证 | 第三届美亚杯(2017)个人赛题解
    快速安装字体.bat批处理脚本
  • 原文地址:https://www.cnblogs.com/zjdxr-up/p/14952422.html
Copyright © 2011-2022 走看看