zoukankan      html  css  js  c++  java
  • Binary Tree Inorder Traversal

    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?

    Recursive Version

    /**
     * Definition for binary tree
     * public class TreeNode {
     *     int val;
     *     TreeNode left;
     *     TreeNode right;
     *     TreeNode(int x) { val = x; }
     * }
     */
    public class Solution {
        public ArrayList<Integer> inorderTraversal(TreeNode root) {
            ArrayList<Integer> res = new ArrayList<Integer>();
            if(root == null) return res;
            
            if(root.left != null){
                /*  ArrayList : addAll(int index, Collection<? extends E> c)
                 *  Inserts all of the elements in the specified collection into this list, starting at the specified position.
                 */
                res.addAll(inorderTraversal(root.left)); 
            }
            res.add(root.val);
            if(root.right != null){
                res.addAll(inorderTraversal(root.right)); 
            }
            
            return res;
        }
    }

     Iterative Version

    public class Solution {
       public  ArrayList<Integer> inorderTraversal(TreeNode root) {
                ArrayList<Integer> res = new ArrayList<Integer>();
                if(root==null) return res;
                
                Stack<TreeNode> s = new Stack<TreeNode>();
                TreeNode cur = root;
                while(!s.isEmpty()||cur!=null){
                   if(cur!=null){
                        s.push(cur); 
                        cur=cur.left;
                    }else{
                        cur=s.pop();
                        res.add(cur.val);
                        cur=cur.right;
                    }
                }
                return res;
            }
    }

    DP

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

    ref: http://www.cnblogs.com/feiling/p/3256607.html

  • 相关阅读:
    spring 配置多个properties
    redis 一些使用过的命令
    ftpclient 遇到的一些问题
    tomcat+nginx 横向扩展
    easyui 刷新页面
    tomcat 发布本地文件
    java httpclient 跳过证书验证
    https增加临时证书,tomcat配置
    echarts getAttribute”的值: 对象为 null 或未定义 错误解决方法,
    数据的导入导出
  • 原文地址:https://www.cnblogs.com/RazerLu/p/3536928.html
Copyright © 2011-2022 走看看