码迷,mamicode.com
首页 > 其他好文 > 详细

[LeetCode#]Binary Tree Inorder Traversal

时间:2015-01-11 06:10:46      阅读:226      评论:0      收藏:0      [点我收藏+]

标签:

The problem:

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

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

   1
         2
    /
   3

 

return [1,3,2].

Note: Recursive solution is trivial, could you do it iteratively?

 

The recursion way is very trivial:

public class Solution {
    public List<Integer> inorderTraversal(TreeNode root) {
    
        ArrayList<Integer> ret = new ArrayList<Integer> ();
        
        if (root == null)
            return ret;
        
        helper(root, ret);
        return ret; 
    }
    
    private void helper(TreeNode cur_root, ArrayList<Integer> ret) {
        
        if (cur_root == null)
            return;
        
        helper(cur_root.left, ret);
        ret.add(cur_root.val);
        helper(cur_root.right, ret);
    }
}

 

[LeetCode#]Binary Tree Inorder Traversal

标签:

原文地址:http://www.cnblogs.com/airwindow/p/4216061.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!