二叉树基础——前序遍历中序遍历后序遍历按层遍历
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二叉树基础——前序遍历中序遍历后序遍历按层遍历相关的知识,希望对你有一定的参考价值。
转载请注明原文地址:
一:树的结点
一般默认树的结点由:结点值、左儿子、右儿子,构造函数组成。
class TreeNode{ int value; TreeNode left; TreeNode right; public TreeNode(int i){ this.value=i; } }
二:二叉树的遍历实现——递归和非递归
1:递归实现==按照遍历方式(前、中、后)对左、根、右的访问顺序去 打印结点值、递归左儿子、递归右儿子
public void preorder(TreeNode root){ if(root==null){ return; } System.out.println(root.val); //根 preorder(root.left,pre);//左 preorder(root.right,pre);//右 } public void inorder(TreeNode root){ if(root==null){ return; } inorder(root.left,in); /左 System.out.println(root.val);//根 inorder(root.right,in);//右 } public void postorder(TreeNode root){ if(root==null){ return; } postorder(root.left,post);//左 postorder(root.right,post);//右 System.out.println(root.val);//根 }
2:非递归实现==使用 栈 来控制结点的处理顺序
以上是关于二叉树基础——前序遍历中序遍历后序遍历按层遍历的主要内容,如果未能解决你的问题,请参考以下文章