`
robinsoncrusoe
  • 浏览: 750340 次
  • 性别: Icon_minigender_2
  • 来自: 深圳
社区版块
存档分类
最新评论

JAVA 二叉树的递归和非递归遍历

    博客分类:
  • JAVA
阅读更多
着重介绍了非递归算法,特别是非递归后续遍历

package edu.cumt.jnotnull;

import java.util.Stack;

public class BinaryTree {
	protected Node root;

	public BinaryTree(Node root) {
		this.root = root;
	}

	public Node getRoot() {
		return root;
	}

	/** 构造树 */
	public static Node init() {
		Node a = new Node('A');
		Node b = new Node('B', null, a);
		Node c = new Node('C');
		Node d = new Node('D', b, c);
		Node e = new Node('E');
		Node f = new Node('F', e, null);
		Node g = new Node('G', null, f);
		Node h = new Node('H', d, g);
		return h;// root
	}

	/** 访问节点 */
	public static void visit(Node p) {
		System.out.print(p.getKey() + " ");
	}

	/** 递归实现前序遍历 */
	protected static void preorder(Node p) {
		if (p != null) {
			visit(p);
			preorder(p.getLeft());
			preorder(p.getRight());
		}
	}

	/** 递归实现中序遍历 */
	protected static void inorder(Node p) {
		if (p != null) {
			inorder(p.getLeft());
			visit(p);
			inorder(p.getRight());
		}
	}

	/** 递归实现后序遍历 */
	protected static void postorder(Node p) {
		if (p != null) {
			postorder(p.getLeft());
			postorder(p.getRight());
			visit(p);
		}
	}

	/** 非递归实现前序遍历 */
	protected static void iterativePreorder(Node p) {
		Stack<Node> stack = new Stack<Node>();
		if (p != null) {
			stack.push(p);
			while (!stack.empty()) {
				p = stack.pop();
				visit(p);
				if (p.getRight() != null)
					stack.push(p.getRight());
				if (p.getLeft() != null)
					stack.push(p.getLeft());
			}
		}
	}

	/** 非递归实现前序遍历2 */
	protected static void iterativePreorder2(Node p) {
		Stack<Node> stack = new Stack<Node>();
		Node node = p;
		while (node != null || stack.size() > 0) {
			while (node != null) {//压入所有的左节点,压入前访问它
				visit(node);
				stack.push(node);
				node = node.getLeft();
			}
			if (stack.size() > 0) {//
				node = stack.pop();
				node = node.getRight();
			}
		}
	}

	/** 非递归实现后序遍历 */
	protected static void iterativePostorder(Node p) {
		Node q = p;
		Stack<Node> stack = new Stack<Node>();
		while (p != null) {
			// 左子树入栈
			for (; p.getLeft() != null; p = p.getLeft())
				stack.push(p);
			// 当前节点无右子或右子已经输出
			while (p != null && (p.getRight() == null || p.getRight() == q)) {
				visit(p);
				q = p;// 记录上一个已输出节点
				if (stack.empty())
					return;
				p = stack.pop();
			}
			// 处理右子
			stack.push(p);
			p = p.getRight();
		}
	}

	/** 非递归实现后序遍历 双栈法 */
	protected static void iterativePostorder2(Node p) {
		Stack<Node> lstack = new Stack<Node>();
		Stack<Node> rstack = new Stack<Node>();
		Node node = p, right;
		do {
			while (node != null) {
				right = node.getRight();
				lstack.push(node);
				rstack.push(right);
				node = node.getLeft();
			}
			node = lstack.pop();
			right = rstack.pop();
			if (right == null) {
				visit(node);
			} else {
				lstack.push(node);
				rstack.push(null);
			}
			node = right;
		} while (lstack.size() > 0 || rstack.size() > 0);
	}

	/** 非递归实现后序遍历 单栈法*/
	protected static void iterativePostorder3(Node p) {
		Stack<Node> stack = new Stack<Node>();
		Node node = p, prev = p;
		while (node != null || stack.size() > 0) {
			while (node != null) {
				stack.push(node);
				node = node.getLeft();
			}
			if (stack.size() > 0) {
				Node temp = stack.peek().getRight();
				if (temp == null || temp == prev) {
					node = stack.pop();
					visit(node);
					prev = node;
					node = null;
				} else {
					node = temp;
				}
			}

		}
	}

	/** 非递归实现后序遍历4 双栈法*/
	protected static void iterativePostorder4(Node p) {
		Stack<Node> stack = new Stack<Node>();
		Stack<Node> temp = new Stack<Node>();
		Node node = p;
		while (node != null || stack.size() > 0) {
			while (node != null) {
				temp.push(node);
				stack.push(node);
				node = node.getRight();
			}
			if (stack.size() > 0) {
				node = stack.pop();
				node = node.getLeft();
			}
		}
		while (temp.size() > 0) {
			node = temp.pop();
			visit(node);
		}
	}

	/** 非递归实现中序遍历 */
	protected static void iterativeInorder(Node p) {
		Stack<Node> stack = new Stack<Node>();
		while (p != null) {
			while (p != null) {
				if (p.getRight() != null)
					stack.push(p.getRight());// 当前节点右子入栈
				stack.push(p);// 当前节点入栈
				p = p.getLeft();
			}
			p = stack.pop();
			while (!stack.empty() && p.getRight() == null) {
				visit(p);
				p = stack.pop();
			}
			visit(p);
			if (!stack.empty())
				p = stack.pop();
			else
				p = null;
		}
	}

	/** 非递归实现中序遍历2 */
	protected static void iterativeInorder2(Node p) {
		Stack<Node> stack = new Stack<Node>();
		Node node = p;
		while (node != null || stack.size() > 0) {
			while (node != null) {
				stack.push(node);
				node = node.getLeft();
			}
			if (stack.size() > 0) {
				node = stack.pop();
				visit(node);
				node = node.getRight();
			}
		}
	}

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		BinaryTree tree = new BinaryTree(init());
		System.out.print(" Pre-Order:");
		preorder(tree.getRoot());
		System.out.println();
		System.out.print("  In-Order:");
		inorder(tree.getRoot());
		System.out.println();
		System.out.print("Post-Order:");
		postorder(tree.getRoot());
		System.out.println();
		System.out.print(" Pre-Order:");
		iterativePreorder(tree.getRoot());
		System.out.println();
		System.out.print("Pre-Order2:");
		iterativePreorder2(tree.getRoot());
		System.out.println();
		System.out.print("  In-Order:");
		iterativeInorder(tree.getRoot());
		System.out.println();
		System.out.print(" In-Order2:");
		iterativeInorder2(tree.getRoot());
		System.out.println();
		System.out.print(" Post-Order:");
		iterativePostorder(tree.getRoot());
		System.out.println();
		System.out.print("Post-Order2:");
		iterativePostorder2(tree.getRoot());
		System.out.println();
		System.out.print("Post-Order3:");
		iterativePostorder3(tree.getRoot());
		System.out.println();
		System.out.print("Post-Order4:");
		iterativePostorder4(tree.getRoot());
		System.out.println();

	}

}

分享到:
评论
2 楼 lengzl 2017-02-09  
请问,那个Node 是哪个包里面的类?
1 楼 gongchuangsu 2016-09-14  
总结的很好,感谢感谢

相关推荐

    java实现的二叉树的递归和非递归遍历

    在提供的"二叉树的递归和非递归遍历"压缩包文件中,可能包含了Java源代码,演示了如何实现这两种遍历方式。通过阅读和理解这些代码,你可以更好地掌握二叉树遍历的原理和实践,这对于理解和解决涉及二叉树的算法问题...

    Java版二叉树遍历非递归程序

    非递归遍历通常使用栈来辅助实现,具体分为以下几种方式: 1. **非递归前序遍历**: - 使用一个栈来保存待访问的节点。 - 如果当前节点不为空,则将其入栈,并将当前节点设置为其左孩子。 - 当栈不为空时,从栈...

    二叉树的非递归遍历方式(Java).md

    详细介绍了JAVA中二叉树的非递归遍历方式,三种方式都是采用栈来辅助完成,其中前序遍历采用的是先入右子节点再入左子节点的方法,这样弹出栈时左在前,右在后。中序遍历的话则是要先一直到达最左的子节点,然后才弹...

    二叉树的遍历(递归+非递归 Java版)

    在Java编程中,二叉树的遍历主要有三种方法:前序遍历、中序遍历和后序遍历。下面将详细介绍这些遍历方法及其递归和非递归实现。 1. **前序遍历**: - **描述**:前序遍历的顺序是“根-左-右”。首先访问根节点,...

    先序遍历二叉树的非递归算法程序

    编写先序遍历二叉树的非递归算法程序,要求: (1)以二叉链表建立二叉树。 (2)输出遍历的结点序列。 (3)有实例验算。

    java二叉树的遍历

    二叉树的遍历可以分为递归遍历和非递归遍历两种方式,分别对应递归函数和非递归算法。递归遍历通过函数的递归调用来访问二叉树的节点,而非递归遍历则使用栈或队列来模拟递归过程。 在Java中,二叉树的遍历可以分为...

    java 二叉树遍历

    在 Java 中,也可以使用栈来实现非递归遍历方式。 (1)非递归先序遍历 void PreOrder2(BiTree T){ stack&lt;BiTree&gt; stack; BiTree p = T; while(p || !stack.empty()){ if(p != NULL){ stack.push(p); p = p-...

    java语言实现的二叉树的各种操作(包括递归与非递归遍历二叉树,求二叉树的高度,节点总数,叶子节点等)

    java语言实现的二叉树的各种操作(包括递归与非递归遍历二叉树,求二叉树的高度,节点总数,叶子节点等)

    Java实现二叉树的遍历

    java实现二叉树非递归前序中序后序遍历

    二叉树的遍历(递归+非递归 Java语言版)

    在Java编程中,二叉树的遍历主要有三种方式:前序遍历、中序遍历和后序遍历。接下来,我们将详细讨论这些遍历方法以及递归和非递归实现。 1. **前序遍历**:前序遍历的顺序是“根-左-右”。首先访问根节点,然后...

    用Python实现二叉树、二叉树非递归遍历及绘制的例子

    如果你用C或者C++或者其他高级语言写过二叉树或者阅读过相关方面代码,应该知道二叉树的非递归遍历避不开通过栈或者队列实现。是的,python也一样。但是python自带的list功能很强大,即可以当stack

    java二叉树的遍历(递归和非递归).pdf

    总结来说,二叉树的递归遍历简洁明了,而非递归遍历则需要借助额外的数据结构(如栈)来控制访问顺序。在实际应用中,选择哪种方式取决于具体需求,例如内存限制、代码可读性等因素。理解这两种遍历方式对于掌握数据...

    二叉树的非递归遍历运算

    二叉树的非递归遍历运算 建立二叉树的三叉链式存储结构,在此基础上完成下列算法: 1) 从键盘上输入二叉树的各个结点,建立三叉链表 2) 输出该二叉树 3) 非递归的层次遍历算法 4) 非递归的先序遍历、中序遍历、...

    二叉树的遍历 java语言实现

    二叉树遍历是访问二叉树中所有节点的过程,通常有三种主要方法:前序遍历、中序遍历和后序遍历。这些遍历方式对于理解和操作二叉树数据结构至关重要。 1. **前序遍历**(Preorder Traversal): - 访问根节点。 -...

    二叉树非递归遍历(树形输出)

    在提供的压缩包文件“二叉树遍历(非递归)”中,可能包含具体的代码示例,这些示例可能涵盖了上述理论的实现,帮助你更好地理解和应用非递归遍历二叉树的方法。通过阅读和分析这些代码,你可以加深对二叉树遍历的...

    二叉树的遍历-java

    在计算机科学中,二叉树遍历是访问树中所有节点的一种基本操作,通常有三种主要的遍历方式:前序遍历、中序遍历和后序遍历。这些遍历方法在数据结构和算法领域中有着广泛的应用,特别是在编译器设计、搜索算法和数据...

    非递归中序遍历二叉树java代码.docx

    非递归中序遍历是一种在不使用递归方法的情况下遍历二叉树的策略,主要依赖于数据结构栈来实现。在这个Java代码示例中,我们看到的是如何使用栈来执行非递归中序遍历的过程。首先,让我们详细了解二叉树和中序遍历的...

    二叉树遍历算法 (递归的、非递归的中序、前序、后序遍历 和 层次遍历 以及 求二叉树的宽度和深度)

    非递归遍历通常借助栈的数据结构来实现。 **1. 前序遍历** 前序遍历的非递归实现可以通过栈来辅助: ```java public void iterativePreOrderTraverse(Node root) { Stack&lt;Node&gt; nodes = new Stack(); if (root !...

    链式二叉树的中序创建、递归中序遍历、非递归堆栈中序遍历、中序销毁

    在本话题中,我们将重点讨论链式二叉树的中序遍历,包括递归和非递归的方法,以及如何创建和销毁这种数据结构。 一、链式二叉树的中序创建 中序创建链式二叉树通常涉及自底向上的构建过程。首先,我们需要创建一个...

    二叉树树的可视化及非递归遍历

    本文主要讨论的是二叉树的可视化以及非递归遍历方法,这两种技术对于理解和操作二叉树至关重要。 首先,我们来谈谈二叉树的可视化。可视化工具可以帮助开发者直观地理解二叉树的结构,这对于调试、教学和学习都非常...

Global site tag (gtag.js) - Google Analytics