LeetCode94 二叉树的中遍历

  1. 题目
    给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。

  2. 示例
    示例 1
    输入:root = [1,null,2,3]
    输出:[1,3,2]
    
    示例 2:
    输入:root = []
    输出:[]
    
    示例 3:
    输入:root = [1]
    输出:[1]

  3. 解题思路
    1. 方法一:递归。
    2. 方法二:循环。
      1. 使用栈保存根节点。
      2. 每次从栈中取出当前根节点,并将其左右子节点,加入栈中。
  4. 代码(Java)
     // 方法一
    class Solution {
        public List<Integer> inorderTraversal(TreeNode root) {
            List<Integer> res = new ArrayList<>();
            midTrav(res, root);
            return res;
        }
        public Integer midTrav(List<Integer> res, TreeNode root) {
            if (root != null) {
                Integer left = midTrav(res, root.left);
                if (left != null) {
                    res.add(left);
                }
                res.add(root.val);
                Integer right = midTrav(res, root.right);
                if (right != null) {
                    res.add(right);
                }
            }
            return null;
        }
    }
    class Solution {
        public List<Integer> inorderTraversal(TreeNode root) {
            List<Integer> res = new ArrayList<>();
            if (root == null) {
                return res;
            }
            Stack<TreeNode> stack = new Stack<TreeNode>();
            while (root != null || !stack.isEmpty()) {
                if (root != null) {
                    stack.push(root);
                    root = root.left;
                } else {
                    root = stack.pop();
                    res.add(root.val);
                    root = root.right;
                }
            }
            return res;
        }
    }

相关推荐

  1. LeetCode94

    2024-03-13 01:46:02       38 阅读
  2. LeetCode 94.

    2024-03-13 01:46:02       33 阅读
  3. LeetCode-94-

    2024-03-13 01:46:02       27 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-13 01:46:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-13 01:46:02       101 阅读
  3. 在Django里面运行非项目文件

    2024-03-13 01:46:02       82 阅读
  4. Python语言-面向对象

    2024-03-13 01:46:02       91 阅读

热门阅读

  1. 3/11Redis学习下

    2024-03-13 01:46:02       45 阅读
  2. 关于 Conda 和 pip,你了解多少

    2024-03-13 01:46:02       45 阅读
  3. 算法训练day42leetcode01背包问题 416. 分割等和子集

    2024-03-13 01:46:02       41 阅读
  4. 笔试题之一道编程题

    2024-03-13 01:46:02       45 阅读
  5. SpringMVC11、文件上传和下载

    2024-03-13 01:46:02       45 阅读
  6. LeetCode 70 爬楼梯

    2024-03-13 01:46:02       42 阅读
  7. mysql笔记:15. 事务和锁

    2024-03-13 01:46:02       39 阅读