Leetcode - Binary Tree Preorder Traversal

My code:

import java.util.ArrayList;
import java.util.List;

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
public class Solution {
    public List<Integer> preorderTraversal(TreeNode root) {
        ArrayList<Integer> result = new ArrayList<Integer>();
        if (root == null)
            return result;
        preorder(root, result);
        return result;
    }
    
    private void preorder(TreeNode root, ArrayList<Integer> result) {
        result.add(root.val);
        if (root.left != null)
            preorder(root.left, result);
        if (root.right != null)
            preorder(root.right, result);
    }
        
}

My test result:

考先序遍歷的,沒什么好說的。

非遞歸寫法:

    public List<TreeNode> preOrder(TreeNode root) {
        if (root == null)
            return null;
        TreeNode p = root;
        Stack<TreeNode> s = new Stack<TreeNode>();
        ArrayList<TreeNode> result = new ArrayList<TreeNode>();
        while (p != null || !s.isEmpty()) {
            while (p != null) {
                result.add(p);
                s.push(p);
                p = p.left;
            }
            
            if (!s.isEmpty()) {
                p = s.pop();
                p = p.right;        
            }
        }
        return result;
    }

**
總結(jié): pre order tree
**

Anyway, Good luck, Richardo!

My code:

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
public class Solution {
    public List<Integer> preorderTraversal(TreeNode root) {
        ArrayList<Integer> ret = new ArrayList<Integer>();
        if (root == null)
            return ret;
        Stack<TreeNode> s = new Stack<TreeNode>();
        TreeNode node = root;
        while (node != null) {
            ret.add(node.val);
            if (node.right != null)
                s.push(node.right);
            node = node.left;
            if (node == null && !s.isEmpty()) {
                node = s.pop();
            }
        }
        return ret;
    }
}

這是我的寫法。就是每次訪問當(dāng)前結(jié)點,然后如果right child != null, 壓入棧中。
curr = curr.left;
然后判斷 curr 是否為 null.如果是,表示走到頭了。那就從棧中彈出元素,開始訪問右側(cè)。
注意循環(huán)判斷條件得是 node != null 而不是棧是否為空。

Anyway, Good luck, Richardo!

My code:

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
public class Solution {
    public List<Integer> preorderTraversal(TreeNode root) {
        List<Integer> ret = new ArrayList<Integer>();
        if (root == null) {
            return ret;
        }
        Stack<TreeNode> st = new Stack<TreeNode>();
        TreeNode p = root;
        while (p != null || !st.isEmpty()) {
            while (p != null) {
                ret.add(p.val);
                st.push(p);
                p = p.left;
            }
            p = st.pop().right;
        }
        
        return ret;
    }
}

復(fù)習(xí)了下 iteration的寫法,但還是沒能寫出來,看了答案。

Anyway, Good luck, Richardo! -- 09/06/2016

Morris traversal:

My code:

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
public class Solution {
    public List<Integer> preorderTraversal(TreeNode root) {
        List<Integer> ret = new ArrayList<Integer>();
        if (root == null) {
            return ret;
        }
        
        TreeNode curr = root;
        while (curr != null) {
            if (curr.left == null) {
                ret.add(curr.val);
                curr = curr.right;
            }
            else {
                TreeNode pre = curr.left;
                while (pre.right != null && pre.right != curr) {
                    pre = pre.right;
                }
                
                if (pre.right == null) {
                    ret.add(curr.val);
                    pre.right = curr;
                    curr = curr.left;
                }
                else {
                    pre.right = null;
                    curr = curr.right;
                }
            }
        }
        
        return ret;
    }
}

reference:
http://www.cnblogs.com/AnnieKim/archive/2013/06/15/morristraversal.html

Anyway, Good luck, Richardo! -- 09/08/2016

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容