博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java二叉树实现及递归与非递归遍历实现
阅读量:5986 次
发布时间:2019-06-20

本文共 2022 字,大约阅读时间需要 6 分钟。

树的遍历分两种: 1、深度优先遍历    1.1 递归算法实现    2.2 非递归算法实现(使用栈存储) 2、广度优先遍历(使用队列存储)
import java.util.*;/** * 类功能描述: 二叉树遍历算法Java实现 * * @version 1.0.0 * @auther Create by Barry * @date Create on 2018/3/12. * @history */public class BinaryTree {    private Node root;    private BinaryTree(Object data){        this.root = new Node(data, null, null);    }    /**     * 1、 深度优先遍历     * 1.1 递归先序遍历     */    public void preOrderTraverse(Node root){        System.out.println(root.data);        preOrderTraverse(root.leftChild);        preOrderTraverse(root.rightChild);    }    /**     * 1、 深度优先遍历     * 1.2 实现非递归先序遍历     */    public void preOrder(){        Stack stack = new Stack();        System.out.println(root.data);        stack.push(stack);        while(!stack.isEmpty()){            Node element = (Node)stack.pop();            System.out.println(element.data);            if(element.rightChild != null){                stack.push(element.rightChild);            }            if(element.leftChild != null){                stack.push(element.leftChild);            }        }    }    /**     * 2、 广度优先遍历     */    public List
breadthTraverse(Node root){ List
allNodes = new LinkedList<>(); if(root == null){ return allNodes; } Deque
queue = new ArrayDeque<>(); queue.add(root); while(!queue.isEmpty()){ Node currentNode = queue.poll(); allNodes.add(currentNode); if(currentNode.leftChild != null){ queue.add(currentNode.leftChild); } if(currentNode.rightChild != null){ queue.add(currentNode.rightChild); } } return allNodes; } class Node{ private Object data; private Node leftChild; private Node rightChild; public Node(Object data, Node leftChild, Node rightChild){ this.data = data; this.leftChild = leftChild; this.rightChild = rightChild; } }}

 

转载地址:http://ybylx.baihongyu.com/

你可能感兴趣的文章
重启,关机命令
查看>>
各种经典布局--“国”字布局
查看>>
jboss启动报错
查看>>
程序员究竟该如何提高效率
查看>>
转面试题:跑灯
查看>>
spring mvc 单元测试
查看>>
swift与Objective-C的互用性
查看>>
Linux 进程管理
查看>>
Linux 线程相关函数理解
查看>>
我的友情链接
查看>>
2.3.1.shell awk 入门
查看>>
snmp在网络中的应用
查看>>
git 使用过程中问题记录
查看>>
SDN in Action: Deploy VXLAN with MP-BGP EV_P_N
查看>>
Maven学习总结(八)——使用Maven构建多模块项目
查看>>
Docker镜像与容器命令
查看>>
Java培训-日期类
查看>>
项目范围管理论文提纲
查看>>
python给qq发邮件
查看>>
关于mysql的 qps tps
查看>>