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、中序遍历的顺序,先遍历左子树,再遍历右子树,最后遍历根节点。

相关推荐
SuniaWang几秒前
Spring AI 2.x 全面指南:架构升级、工具调用、多模型生态与实战示例
java·人工智能·后端·学习·spring·框架
闻哥1 分钟前
Elasticsearch查询优化实战:从原理到落地的全方位调优指南
java·大数据·elasticsearch·搜索引擎·面试·全文检索·springboot
民乐团扒谱机5 分钟前
【读论文】引力与惯性的起源:从全息原理到牛顿定律与爱因斯坦方程
算法·量子力学··万有引力·爱因斯坦方程·全息原理·牛顿定律
努力学算法的蒟蒻8 分钟前
day84(2.13)——leetcode面试经典150
算法·leetcode·面试
@––––––10 分钟前
力扣hot100—系列8-回溯算法
javascript·算法·leetcode
!停11 分钟前
数据结构二叉树—堆(2)&链式结构(上)
数据结构·算法
三小河15 分钟前
React 样式——styled-components
前端·javascript·后端
C++ 老炮儿的技术栈16 分钟前
万物皆文件:Linux 抽象哲学的开发之美
c语言·开发语言·c++·qt·算法
im_AMBER17 分钟前
Leetcode 120 求根节点到叶节点数字之和 | 完全二叉树的节点个数
数据结构·学习·算法·leetcode·二叉树·深度优先
1027lonikitave19 分钟前
FFTW的expr.ml怎么起作用
算法·哈希算法