Binary Tree Non-recursive Traversal

Preorder:

    public static void BSTPreorderTraverse(Node node) {
        if (node == null) {
            return;
        }
        Stack<Node> s = new Stack<Node>();
        s.push(node);
        while (!s.empty()) {
            node = s.pop();
            System.out.println(node.toString());
            if (node.rightChild != null) {s.push(node.rightChild);}
            if (node.leftChild != null) {s.push(node.leftChild);}
        }
    }

Inorder:

 1 public static void BSTInorderTraverse(Node node) {
 2     Stack<Node> s = new Stack<Node>();
 3     while (!s.empty() || node != null) {
 4         if (node != null) {
 5             s.push(node);
 6             node = node.leftChild;
 7         } else {
 8             node = s.pop();
 9             System.out.println(node.toString());
10             node = node.rightChild;
11         }
12     }
13 }

Postorder:

 1 public List<Integer> postorderTraversal(TreeNode root) {
 2         List<Integer> res = new ArrayList<Integer>();
 3
 4         if (root == null) {
 5             return res;
 6         }
 7
 8         Stack<TreeNode> stack = new Stack<TreeNode>();
 9         stack.push(root);
10
11         while (!stack.isEmpty()) {
12             TreeNode temp = stack.peek();
13             if (temp.left == null && temp.right == null) {
14                 TreeNode pop = stack.pop();
15                 res.add(pop.val);
16             } else {
17                 if (temp.right != null) {
18                     stack.push(temp.right);
19                     temp.right = null; // if we don‘t want to change the tree structure, we can use a set to check whether the node‘s children have been added to the stack or not.
20                 }
21
22                 if (temp.left != null) {
23                     stack.push(temp.left);
24                     temp.left = null;
25                 }
26             }
27         }
28
29         return res;
30     }
时间: 2024-07-28 20:50:21

Binary Tree Non-recursive Traversal的相关文章

[LeetCode]Binary Tree Level Order Traversal II

Binary Tree Level Order Traversal II Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left to right, level by level from leaf to root). For example:Given binary tree {3,9,20,#,#,15,7}, 3 / 9 20 / 15 7 re

Leetcode题解(1):L102/Binary Tree Level Order Traversal

L102: Binary Tree Level Order Traversal Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, level by level). For example: Given binary tree {3,9,20,#,#,15,7}, 3 / \ 9 20 / \ 15 7 return its level order

33: Binary Tree Level Order Traversal II

/************************************************************************/        /*       33:      Binary Tree Level Order Traversal II                                         */        /**************************************************************

Binary Tree Level Order Traversal II 解题思路

思路: 与Binary Tree Level Order Traversal I 几乎一样.只是最后将结果存放在栈里,然后在栈里再传给向量即可. 再次总结思路: 两个queue,先把第一个放进q1,循环q1是否为空,不为空就读取并出列,如果root有孩子就放入q2,最后清空q2. 注意: for循环的时候不要使用vector.size()这类作为最大值判断,由于vector的size可能不断的减小,这回导致遍历不完的情况发生. 即: int count = sret.size(); for(in

LeetCode OJ - Binary Tree Level Order Traversal 1 &amp;&amp; 2

BFS以及它的扩展,我发现栈是个很好用的数据结构,特别是对于顺序需要颠倒的时候!!! 这里有个重要的信息:可以用null来标识一个level的结束!!! 下面是AC代码: 1 /** 2 * Given a binary tree, return the bottom-up level order traversal of its nodes' values. 3 * (ie, from left to right, level by level from leaf to root). 4 *

leetCode 107. Binary Tree Level Order Traversal II 二叉树层次遍历反转

107. Binary Tree Level Order Traversal II Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left to right, level by level from leaf to root). For example:Given binary tree [3,9,20,null,null,15,7],     3  

32: Binary Tree Level Order Traversal

/************************************************************************/        /*       32:      Binary Tree Level Order Traversal                                          */        /****************************************************************

Binary Tree Level Order Traversal java实现

Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, level by level). For example:Given binary tree {3,9,20,#,#,15,7}, 3 / 9 20 / 15 7 return its level order traversal as: [ [3], [9,20], [15,7] ] 实现的关键在

[leetcode]Binary Tree Level Order Traversal @ Python

原题地址:http://oj.leetcode.com/problems/binary-tree-level-order-traversal/ 题意:二叉树的层序遍历的实现. 解题思路:二叉树的层序遍历可以用bfs或者dfs来实现.这里使用的dfs实现,代码比较简洁.实际上,二叉树的先序遍历就是dfs实现.   比如一棵树如下: 1 /  \ 2       3 /    \    /   \ 4     5  6    7    二叉树的先序遍历为{1,2,4,5,3,6,7},可以看到这个遍

leetcode笔记:Binary Tree Level Order Traversal II

一. 题目描述 Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left to right, level by level from leaf to root). For example: Given binary tree {3,9,20,#,#,15,7}, 3 / 9 20 / 15 7 二. 题目分析 由于使用了vector,这一题只需Binar