`

二叉树的遍历

 
阅读更多

        二叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的。对于二叉树,有前序、中序以及后序三种遍历方法。因为树的定义本身就是递归定义,因此采用递归的方法去实现树的三种遍历不仅容易理解而且代码很简洁。而对于树的遍历若采用非递归的方法,就要采用栈去模拟实现。在三种遍历中,前序和中序遍历的非递归算法都很容易实现,非递归后序遍历实现起来相对来说要难一点。


        Java实现二叉树遍历算法相关代码如下:

package cn.xj.bitree;

public class BiTreeNode {
	
	private char data;
	private BiTreeNode leftNode;
	private BiTreeNode rightNode;

	public BiTreeNode(char data, BiTreeNode leftNode, BiTreeNode rightNode) {
		this.data = data;
		this.leftNode = leftNode;
		this.rightNode = rightNode;
	}
	
	public char getData() {
		return data;
	}
	public void setData(char data) {
		this.data = data;
	}
	
	public BiTreeNode getLeftNode() {
		return leftNode;
	}
	public void setLeftNode(BiTreeNode leftNode) {
		this.leftNode = leftNode;
	}
	
	public BiTreeNode getRightNode() {
		return rightNode;
	}
	public void setRightNode(BiTreeNode rightNode) {
		this.rightNode = rightNode;
	}
}

 

package cn.xj.bitree;

import java.util.Stack;

public class BiTree {
	
	private BiTreeNode rootNode;
	
	public BiTree(BiTreeNode rootNode) {
		this.rootNode = rootNode;
	}

	public BiTreeNode getRootNode() {
		return rootNode;
	}
	
	//构造树
	public static BiTreeNode init(){
		BiTreeNode a = new BiTreeNode('A',null,null);  
		BiTreeNode b = new BiTreeNode('B', null, a);   
		BiTreeNode c = new BiTreeNode('C',null,null);   
		BiTreeNode d = new BiTreeNode('D', b, c);   
		BiTreeNode e = new BiTreeNode('E',null,null);   
		BiTreeNode f = new BiTreeNode('F', e, null);   
		BiTreeNode g = new BiTreeNode('G', null, f);   
		BiTreeNode h = new BiTreeNode('H', d, g);   
		return h;// root
	}
	
	//打印节点
	public void visit(BiTreeNode node){
		System.out.print(node.getData()+"");
	}
	
	//递归
	/**递归实现前序遍历:根首先访问*/
	public void preOrder(BiTreeNode node){
		if(node!=null){
			visit(node);
			preOrder(node.getLeftNode());			
			preOrder(node.getRightNode());
		}
	}
	/**递归实现中序遍历:根中间访问*/
	public void midOrder(BiTreeNode node){
		if(node!=null){			
			midOrder(node.getLeftNode());
			visit(node);
			midOrder(node.getRightNode());
		}
	}
	/**递归实现后序遍历:根最后访问*/
	public void poster(BiTreeNode node){
		if(node!=null){
			poster(node.getLeftNode());
			poster(node.getRightNode());
			visit(node);
		}
	}
	
	
	
	
	//非递归
	/**非递归前序遍历*/
	public void iterativePre(BiTreeNode node){
		Stack<BiTreeNode> stack = new Stack<BiTreeNode>();
		if(node!=null){
			stack.push(node);
			while(!stack.isEmpty()){
				node = stack.pop();
				visit(node);  //先访问根节点,栈底节点
				if(node.getRightNode()!=null)
					stack.push(node.getRightNode());//右节点进栈,等同于stack.add(node.getRightNode());					 
				if(node.getLeftNode()!=null)
					stack.push(node.getLeftNode());	//左节点进栈stack.add(node.getLeftNode());			
			}
		}
	}
	/**非递归实现中序遍历*/
	public void iterativeMid(BiTreeNode p){
		Stack<BiTreeNode> stack = new Stack<BiTreeNode>();
		while (p != null) { 
			//先按右中左的顺序把所有节点放入栈;
			while(p!=null){
				if(p.getRightNode()!=null)
					stack.push(p.getRightNode());// 当前节点右子入栈 
				stack.push(p);// 当前节点入栈
				p = p.getLeftNode();			
			}
			p = stack.pop();
			while(!stack.empty()&&p.getRightNode()==null){
				visit(p);
				p = stack.pop();
			}
			visit(p);
			if(!stack.empty())
				p = stack.pop();
			else
				p = null;
		}
	
	}
	/**非递归实现后序遍历*/
	public void iterativePost(BiTreeNode p){
		BiTreeNode q = p;
		Stack<BiTreeNode> stack = new Stack<BiTreeNode>();
		while(p!=null){
			//左子树入栈
			for(;p.getLeftNode()!=null;p=p.getLeftNode())
				stack.push(p);
			//当前节点无右子或右子已经输出
			while(p!=null&&(p.getRightNode()==null||p.getRightNode()==q)){
				visit(p);
				q=p;//记录上一个已输出节点
				if(stack.empty())
					return;
				p = stack.pop();
			}
			//处理右子节点
			stack.push(p);
			p=p.getRightNode();
		}
	}
	
	
	public static void main(String[] args){
		BiTree tree = new BiTree(init());
		
		/**递归*/
		System.out.print("Pre-Order:");
		tree.preOrder(tree.getRootNode());
		System.out.println();
		System.out.print("Mid-Order:");
		tree.midOrder(tree.getRootNode());
		System.out.println();
		System.out.print("Post-Order:");   
		tree.poster(tree.getRootNode());  
		
		System.out.println("\r\n------------");
		
		/**非递归*/
		System.out.print("非递归Pre-Order:");
		tree.iterativePre(tree.getRootNode());
		System.out.println();
		System.out.print("非递归Mid-Order:");
		tree.iterativeMid(tree.getRootNode());
		System.out.println();
		System.out.print("非递归Post-Order:");
		tree.iterativePost(tree.getRootNode());
	}
}

 

分享到:
评论

相关推荐

    二叉树遍历的特点(数据结构)C语言描述

    ### 二叉树遍历的特点(数据结构) 在计算机科学领域,数据结构是研究的核心之一。其中,二叉树作为一种重要的非线性数据结构,在实际应用中极为广泛,包括搜索算法、排序算法等方面都有其身影。本文将详细介绍...

    二叉树遍历及其应用

    ### 二叉树遍历及其应用 #### 一、引言 在计算机科学领域,《数据结构》是一门极为重要的基础课程。它不仅涵盖了各种数据结构的设计与实现,还涉及到了算法的设计与分析。其中,二叉树作为一种常用的数据结构,在...

    【C语言二叉树遍历实例】C语言二叉树遍历实例

    二叉树的遍历C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历...

    易语言二叉树遍历

    二叉树遍历是理解数据结构和算法的基础,它包括前序遍历、中序遍历和后序遍历三种主要方法。 1. **二叉树的基本概念**: - 二叉树是一种特殊的树结构,每个节点最多有两个子节点,通常称为左子节点和右子节点。 -...

    数据结构 二叉树遍历程序

    二叉树遍历是理解二叉树操作的关键部分,主要包括先序遍历、中序遍历和后序遍历三种方式。 1. 先序遍历(Preorder Traversal): 先序遍历的顺序是根节点 -&gt; 左子树 -&gt; 右子树。在C语言实现中,一般采用递归的方法...

    二叉树遍历算法的应用

    二叉树遍历算法在IT领域中是一种基础且重要的数据结构操作技术,广泛应用于各种问题的解决。在本文中,我们将深入探讨二叉树遍历的原理及其在统计二叉树节点数量、叶子节点计数以及计算树深等方面的应用。 二叉树...

    堆栈实现二叉树遍历数据结构C语言

    从给定的文件信息来看,该文件主要围绕“堆栈实现二叉树遍历数据结构”的主题,通过C语言编程来实现。以下是基于标题、描述、标签和部分内容的知识点总结和详细说明: ### 1. 数据结构基础 数据结构是计算机科学的...

    实现先序,中序和后序遍历的二叉树遍历程序

    二叉树遍历是针对这种数据结构的一种基本操作,用于按照特定顺序访问树中的所有节点。本程序实现了三种主要的二叉树遍历方法:先序遍历、中序遍历和后序遍历。以下是关于这些遍历方法的详细解释: 1. 先序遍历...

    数据结构树和二叉树遍历二叉树和线索二叉树PPT学习教案.pptx

    "数据结构树和二叉树遍历二叉树和线索二叉树PPT学习教案.pptx" 本资源主要讲述了数据结构树和二叉树遍历的相关知识点,包括二叉树的基本概念、二叉树遍历的六种方案、先序、中序、后序遍历算法的实现、线索二叉树的...

    数据结构实验-3二叉树遍历与路径查找(二叉树实验)

    实验三 二叉树遍历与路径查找(二叉树实验) 实现功能:建立二叉树存储结构、求二叉树的先序遍历、求二叉树的中序遍历、求二叉树的后序遍历、求二叉树的层次遍历、求根到给定结点的路径。 主控菜单: 1.建立二叉树...

    matlab实现二叉树遍历算法(源代码)

    ### MATLAB 实现二叉树遍历算法的知识点详解 #### 一、二叉树节点结构体定义 在MATLAB中实现二叉树的第一步是定义一个表示二叉树节点的结构体。在这个例子中,作者定义了一个名为`TreeNode`的类来表示节点,该类...

    数据结构 二叉树遍历

    #### 1.2 二叉树遍历 遍历是指按照某种顺序访问二叉树中的所有节点,且每个节点只被访问一次的过程。二叉树常见的遍历方式包括:先序遍历、中序遍历和后序遍历。 ### 二、二叉树遍历方法 #### 2.1 先序遍历(前序...

    二叉树遍历的算24程序

    java 写的算24程序。用两种二叉树遍历,并规整输出字符串

    二叉树遍历 二叉树遍历

    二叉树遍历 二叉树遍历

    二叉树遍历流程图(先序、中序、后序、宽度遍历)

    二叉树遍历是计算机科学中处理树结构数据时常用的一种技术,主要分为四种类型:先序遍历、中序遍历、后序遍历和宽度优先遍历。这些遍历方法各有特点,适用于不同的场景。 1. **先序遍历**: - **递归实现**:先...

    二叉树遍历(递归算法)

    二叉树遍历是计算机科学中数据结构领域的一个重要概念,尤其在算法设计与分析中占有举足轻重的地位。二叉树是一种特殊的图结构,每个节点最多有两个子节点,通常分为左子节点和右子节点。二叉树遍历是指按照特定顺序...

    二叉树遍历问题-二叉树遍历问题

    二叉树遍历是计算机科学中的一个重要概念,主要应用于数据结构和算法领域。二叉树是一种特殊的树形数据结构,每个节点最多有两个子节点,通常称为左子节点和右子节点。二叉树遍历是指按照特定顺序访问二叉树的所有...

    二叉树遍历

    二叉树遍历是计算机科学中的一个重要概念,特别是在数据结构和算法领域。它涉及到对二叉树这种数据结构的所有节点进行有序访问。二叉树是由节点组成的,每个节点最多有两个子节点,通常分为左子节点和右子节点。在...

    二叉树遍历问题-前序, 中序, 后序

    二叉树遍历问题 二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序...

    二叉树遍历操作.cpp

    二叉树遍历操作.cpp

Global site tag (gtag.js) - Google Analytics