前序遍历:
/*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode(int x) { val = x; }* }*/
class Solution {public List<Integer> preorderTraversal(TreeNode root) {List<Integer>list=new ArrayList<Integer>();Stack<TreeNode>stack=new Stack<TreeNode>();while(root!=null||!stack.isEmpty()){while(root!=null){list.add(root.val);stack.push(root);root=root.left;}if(!stack.isEmpty()){root=stack.pop();root=root.right;}}return list;}
}
不是二叉树可以前序遍历么、中序迭代遍历:
/*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode(int x) { val = x; }* }*/
class Solution {public List<Integer> inorderTraversal(TreeNode root) {List<Integer> list=new ArrayList<Integer>();Stack<TreeNode>stack=new Stack<TreeNode>(); while(root!=null||!stack.isEmpty()) {while(root!=null) {//先将左结点入栈stack.push(root);root=root.left;}if(!stack.empty()) {root=stack.pop();list.add(root.val);root=root.right;//如果当前结点有右结点遍历它的右结点}}return list;}
}
后序迭代遍历:
/*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode(int x) { val = x; }* }*/
class Solution {public List<Integer> postorderTraversal(TreeNode root) {List<Integer>list=new ArrayList<Integer>();Stack<TreeNode>stack=new Stack<TreeNode>();TreeNode q=null;while(root!=null||!stack.isEmpty()) {while(root!=null) {stack.push(root);root=root.left;}if(!stack.empty()) {root=stack.peek();//取得结点但不让它出栈if((root.right==null)||(root.right==q)){//判断该节点的右结点是否访问过stack.pop();list.add(root.val);q=root;root=null;}else{root=root.right;}}}return list;}
}
二叉树的遍历图解例题。
版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。
工作时间:8:00-18:00
客服电话
电子邮件
admin@qq.com
扫码二维码
获取最新动态