首页 > 其他 > 详细

[leetcode] Binary Tree Postorder Traversal

时间:2015-01-01 07:51:50      阅读:249      评论:0      收藏:0      [点我收藏+]

题目:(Tree ,Stack)

Given a binary tree, return the postorder traversal of its nodes‘ values.

For example:
Given binary tree {1,#,2,3},

   1
         2
    /
   3

 

return [3,2,1].

题解:


binary tree 三部曲里面最难的一个。多看看。

/**
 * Definition for binary tree
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
public class Solution {
    public ArrayList<Integer> postorderTraversal(TreeNode root) {
       ArrayList<Integer> result = new ArrayList<Integer>();
       if(root==null)
            return result;
       
       Stack<TreeNode> stack=new Stack<TreeNode>();
       stack.push(root);
       TreeNode prev=null;
       
       while(!stack.isEmpty()){
           TreeNode current=stack.peek();
           if(prev==null||prev.left==current||prev.right==current)
           {
               if(current.left!=null)
                   stack.push(current.left);
               else if(current.right!=null)
                   stack.push(current.right);
               else
               {
                   stack.pop();
                   result.add(current.val);
               }
           }else if(prev==current.left)
           {
               if(current.right!=null)
                   stack.push(current.right); 
               else
               {
                   stack.pop();
                   result.add(current.val);
               }
           }else
           {
               stack.pop();
               result.add(current.val);
           }
           prev=current;
       }
       return result;
    }
}

 

[leetcode] Binary Tree Postorder Traversal

原文:http://www.cnblogs.com/fengmangZoo/p/4196980.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!