【无标题】

记录

2025.4.19

题目:

思路:

按照访问左子树------根节点------右子树的方式遍历这棵树

解题步骤:

定义 inorder(root) 表示当前遍历到 root 节点的答案,那么按照定义,我们只要递归调用 inorder(root.left) 来遍历 root 节点的左子树,然后将 root 节点的值加入答案,再递归调用inorder(root.right) 来遍历 root 节点的右子树即可,递归终止的条件为碰到空节点。

代码:

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public List<Integer> inorderTraversal(TreeNode root) {
        List<Integer> res = new ArrayList<Integer>();
        inorder(root, res);
        return res;
    }

    public void inorder(TreeNode root, List<Integer> res) {
        if (root == null) {
            return;
        }
        inorder(root.left, res);
        res.add(root.val);
        inorder(root.right, res);
    }
}

复杂度:

N(N)

N(N)

相关推荐
顾林海2 分钟前
深度解析CopyWriteArrayList工作原理
android·java·面试
慧一居士4 分钟前
Spring Boot集成MongoDB及实战技巧与性能调优
java·spring boot·mongodb
西岭千秋雪_5 分钟前
Nacos配置中心客户端处理服务端配置信息源码解析
java·开发语言·分布式·spring·微服务·中间件
SimonKing12 分钟前
JDBC你肯定听过,那JDBC Loadbalance你用过么?
java·后端·架构
菲英的学习笔记15 分钟前
C++面试题集合(附答案)
java·c++·面试·职场和发展
Java技术小馆18 分钟前
Java死锁不是会让CPU爆表吗
java·面试·架构
xjm爱学习20 分钟前
easy-query JAVA下最强查询ORM没有之一的任意子查询合并革命性OLAP优化
java
无名的小码农23 分钟前
【62期获取股票数据API接口】如何用Python、Java等五种主流语言实例演示获取股票行情API接口之沪深A股派现与募资对比数据及接口API说明文档
java·开发语言·python·股票api·股票数据接口·股票数据
申城异乡人27 分钟前
【深度思考】自定义日期格式,为什么@JSONField生效,@JsonFormat不生效?
java