LeetCode第94题二叉树的中序遍历

继续打卡算法题,今天学习的是LeetCode第94题二叉树的中序遍历,这道题目是道简单题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些提升。

分析一波题目

哈哈,遍历树的题目,我们都可以使用递归法,和回溯算法类似,本题是中序遍历,记住按左根右节点的顺序遍历,就是父节点要在遍历的中间。

本题解题技巧

1、记住中序遍历的顺序,先找左子树,再找根节点,再找右子树

编码解决

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> result = new ArrayList<>();
        dfs(result, root);
        return result;

    }

    public void dfs(List<Integer> result, TreeNode node) {

       if(node == null) {
           return;
       }

       TreeNode left = node.left;
       //遍历左子树
       dfs(result, left);
        //遍历根节点
       int v = node.val;
       result.add(v);

        TreeNode right = node.right;
        //遍历右子树
       dfs(result, right);
    }
}

总结

1、递归法遍历树是比较好理解的,代码也比较简洁,我们记住这种解法,可以解决很多树相关的题目。

2、中序遍历的顺序,先遍历左子树,再遍历右子树,最后遍历根节点。

相关推荐
minji...21 分钟前
Linux 进程信号(二)信号的保存,sigset_t,sigprocmask,sigpending
linux·运维·服务器·网络·数据结构·c++·算法
庞轩px23 分钟前
模拟面试回答第十三问:JVM内存模型
jvm·面试·职场和发展
Victor35628 分钟前
MongoDB(69)如何进行增量备份?
后端
Victor35634 分钟前
MongoDB(70)如何使用副本集进行备份?
后端
罗湖老棍子38 分钟前
最大数(信息学奥赛一本通- P1549)(洛谷-P1198)
数据结构·算法·线段树·单点修改 区间求最大值
人工智能AI技术1 小时前
计算机专业面试必看!90%学生都踩过的算法面雷区
人工智能·面试
千寻girling1 小时前
面试官 : “ 说一下 Python 中的常用的 字符串和数组 的 方法有哪些 ? ”
人工智能·后端·python
小O的算法实验室2 小时前
2026年KBS,赏金猎人优化算法+多无人机移动边缘计算与路径规划,深度解析+性能实测
算法·无人机·边缘计算
ywf12152 小时前
Spring Boot接收参数的19种方式
java·spring boot·后端
xlp666hub2 小时前
深度剖析 Linux Input 子系统(3):从零写一个 Input 驱动,最详细手把手(附完整代码)
linux·面试