本文实例讲述了java实现二叉树的深度优先遍历和广度优先遍历算法。分享给大家供大家参考,具体如下:
1. 分析
二叉树的深度优先遍历的非递归的通用做法是采用栈,广度优先遍历的非递归的通用做法是采用队列。
深度优先遍历:对每一个可能的分支路径深入到不能再深入为止,而且每个结点只能访问一次。要特别注意的是,二叉树的深度优先遍历比较特殊,可以细分为先序遍历、中序遍历、后序遍历。具体说明如下:
先序遍历:对任一子树,先访问根,然后遍历其左子树,最后遍历其右子树。
中序遍历:对任一子树,先遍历其左子树,然后访问根,最后遍历其右子树。
后序遍历:对任一子树,先遍历其左子树,然后遍历其右子树,最后访问根。
广度优先遍历:又叫层次遍历,从上往下对每一层依次访问,在每一层中,从左往右(也可以从右往左)访问结点,访问完一层就进入下一层,直到没有结点可以访问为止。
2. 举例说明
对下图所示的二叉排序树进行遍历,要求使用先序遍历(递归、非递归)、中序遍历(递归、非递归)、后序遍历(递归、非递归)和广度优先遍历。
① 参考代码
package binarytreetraversetest;
import java.util.linkedlist;
import java.util.queue;
/**
* 二叉树的深度优先遍历和广度优先遍历
* @author fantasy
* @version 1.0 2016/10/05 - 2016/10/07
*/
public class binarytreetraversetest {
public static void main(string[] args) {
binarysorttree tree = new binarysorttree();
tree.insertnode(35);
tree.insertnode(20);
tree.insertnode(15);
tree.insertnode(16);
tree.insertnode(29);
tree.insertnode(28);
tree.insertnode(30);
tree.insertnode(40);
tree.insertnode(50);
tree.insertnode(45);
tree.insertnode(55);
system.out.