• 二叉搜索树02--[前序/中序/后序/层次遍历&&接口设计]


    1.二叉树的遍历

    1.1前序遍历

    递归遍历

    前序非递归遍历

     

      

    代码-递归版本

        /**
         * 前序遍历
         */
        public void preorderTraversal() {
            preorderTraversal(root);
        }
        
        private void preorderTraversal(Node<E> node) {
            if (node == null) return;
            
            System.out.println(node.element);
            preorderTraversal(node.left);
            preorderTraversal(node.right);
        }
    View Code

    1.3中序遍历

    递归遍历

     非递归遍历

     

     代码--递归版本

        /**
         * 中序遍历
         */
        public void inorderTraversal() {
            inorderTraversal(root);
        }
        
        private void inorderTraversal(Node<E> node) {
            if (node == null) return;
            
            inorderTraversal(node.left);
            System.out.println(node.element);
            inorderTraversal(node.right);
        }
    View Code

     1.4后序遍历

    递归遍历

     非递归遍历

     

    代码--递归版本

        /**
         * 后序遍历
         */
        public void postorderTraversal() {
            postorderTraversal(root);
        }
        
        private void postorderTraversal(Node<E> node) {
            if (node == null) return;
    
            postorderTraversal(node.left);
            postorderTraversal(node.right);
            System.out.println(node.element);
        }
    View Code

    1.5层次遍历

    递归版本

     

     代码--递归版本

        /**
         * 层序遍历
         */
        public void levelOrderTraversal() {
            if (root == null) return;
            
            Queue<Node<E>> queue = new LinkedList<>();
            queue.offer(root);
            
            while (!queue.isEmpty()) {
                Node<E> node = queue.poll();
                System.out.println(node.element);
                
                if (node.left != null) {
                    queue.offer(node.left);
                }
                
                if (node.right != null) {
                    queue.offer(node.right);
                }
            }
        }
    View Code

    2.遍历接口设计

    2.1控制遍历元素的输出设计

    代码

    BinarySearchTree.java

    public static interface  Visitor<E> {
            
             void  visit(E element);
        }    
    public void inorder(Visitor<E> visitor) {
            if (visitor == null) return;
            inorder(root, visitor);
        }
        
        private void inorder(Node<E> node, Visitor<E> visitor) {
            //这是递归终止
            if (node == null || visitor.stop) return;
            
            inorder(node.left, visitor);
            //这是打印终止
            if (visitor.stop) return;
            visitor.stop = visitor.visit(node.element);
            inorder(node.right, visitor);
        }
    View Code

    main.java

    bst.inorder(new Visitor<Integer>() {
            public void visit(Integer element) {
                System.out.print(element );
            }
        });
    View Code

    2.2增强遍历接口--控制遍历的个数 在什么时候进行停止操作

     

    代码

    BinarySearchTree.java

        public static abstract class Visitor<E> {
            boolean stop;
            /**
             * @return 如果返回true,就代表停止遍历
             */
            public abstract boolean visit(E element);
        }
            
        public void inorder(Visitor<E> visitor) {
            if (visitor == null) return;
            inorder(root, visitor);
        }
        
        private void inorder(Node<E> node, Visitor<E> visitor) {
            if (node == null || visitor.stop) return;
            
            inorder(node.left, visitor);
            if (visitor.stop) return;
            visitor.stop = visitor.visit(node.element);
            inorder(node.right, visitor);
        }
    View Code

    main.java

    bst.inorder(new Visitor<Integer>() {
                public boolean visit(Integer element) {
                    System.out.print(element + " ");
                    return element == 4 ? true : false;
                }
            });
    View Code

    3.遍历的应用

  • 相关阅读:
    Javascript之in操作符的用法
    auguements实参对象的数组化
    jQuery多库共存问题解决方法
    JS框架设计之命名空间设计一种子模块
    WebStorm 快键键
    Sington单例模式(创建型模式)
    Asp.Net Cache缓存技术学习
    跨域
    webuploader跨域上传
    BuiltWith
  • 原文地址:https://www.cnblogs.com/ggnbnb/p/12292323.html
Copyright © 2020-2023  润新知