zoukankan      html  css  js  c++  java
  • 排序二叉树的基本操作

    描述

    二叉树的构建、插入新的结点、树的先中后序以及层序四种遍历

    代码

    import java.util.LinkedList;
    import java.util.Queue;
    
    class Node{
        public int data;
        public Node left;
        public Node right;
        public Node(int data){
            this.data=data;
            this.left=null;
            this.right=null;
        }
    }
    
    public class BinaryTree {
        private Node root;
        public BinaryTree(){
            root=null;
        }
        /*
        * 插入到排序二叉树
        * */
        public void insert(int data){
            Node newNode=new Node(data);
            if(root==null){
                root=newNode;
                return;
            }
            Node node=root;
            Node parent;
            while(true){
                parent=node;
                if(data<node.data){
                    node=node.left;
                    if(node==null){
                        parent.left=newNode;
                        return;
                    }
                }else{
                    node=node.right;
                    if(node==null){
                        parent.right=newNode;
                        return;
                    }
                }
            }
        }
        /*
        * 将数值输入构建二叉树
        * */
        public void buildTree(int[] data){
            for(int i=0;i<data.length;i++){
                insert(data[i]);
            }
        }
        /*
        * 先序遍历
        * */
        public void preOrder(){
            preOrder(root);
        }
        public void preOrder(Node node){
            if(node==null) return;
            System.out.print(node.data+" ");
            preOrder(node.left);
            preOrder(node.right);
        }
    
        /*
        * 中序遍历
        * */
        public void inOrder(){
            inOrder(root);
        }
        public void inOrder(Node node){
            if(node==null) return;
            inOrder(node.left);
            System.out.print(node.data+" ");
            inOrder(node.right);
        }
    
        /*
        * 后序遍历
        * */
        public void postOrder(){
            postOrder(root);
        }
        public void postOrder(Node node){
            if(node==null) return;
            postOrder(node.left);
            postOrder(node.right);
            System.out.print(node.data+" ");
        }
        /*
        * 层序遍历
        * */
        public void layerTranverse(){
            Node node = root;
            Queue<Node> queque=new LinkedList<Node>();
            queque.add(root);
            while(!queque.isEmpty()){
                node=queque.poll();
                System.out.print(node.data+" ");
                if(node.left!=null) queque.add(node.left);
                if(node.right!=null) queque.add(node.right);
            }
        }
    
        public static void main(String[] args) {
            BinaryTree bitree=new BinaryTree();
            int[] data={2,8,7,4,9,3,1,6,7,5};
            bitree.buildTree(data);
            System.out.print("二叉树的先序遍历:");
            bitree.preOrder();
            System.out.println();
            System.out.print("二叉树的中序遍历:");
            bitree.inOrder();
            System.out.println();
            System.out.print("二叉树的后序遍历:");
            bitree.postOrder();
            System.out.println();
            System.out.print("二叉树的层序遍历:");
            bitree.layerTranverse();
            System.out.println();
        }
    }
  • 相关阅读:
    小白的源码阅读之旅_RazorEngine_起因
    Sqlserver_小工具_Json解析
    Sqlserver_小工具_批量字段约束处理
    SqlServer_小工具_获取数据库空间信息获取
    SqlServer_小工具_系统表的使用
    Sqlserver_小工具_字符统计(区分大小写)
    SqlServer_小工具_存储空间单位自适应
    不断优化,重构我的代码-----拖拽jquery插件
    canvas绘制二次贝塞尔曲线----演示二次贝塞尔四个参数的作用
    requestAnimationFrame与setInterval,setTimeout
  • 原文地址:https://www.cnblogs.com/zadomn0920/p/6361730.html
Copyright © 2011-2022 走看看