算法工程题(中序遍历)

复制代码
*  题意说明:
*  给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。
*
*  示例 1:
*  输入:root = [1,null,2,3]
*  输出:[1,3,2]
*
*  示例 2:
*  输入:root = []
*  输出:[]
*
*  示例 3:
*  输入:root = [1]
*  输出:[1]
*
*  提示:
*  树中节点数目在范围 [0, 100] 内
*  -100 <= Node.val <= 100
*  进阶: 递归算法很简单,你可以通过迭代算法完成吗?
*
*  Related Topics
*  栈
*  树
*  深度优先搜索
*  二叉树
*
* @Date 2023/8/30 10:07
* @Version 1.0
*/
java 复制代码
public class InorderTraversal {

    public static void main(String[] args) {
        // 测试代码入口
    }
    public static List<Integer> inorderTraversal(TreeNode root) {

        return null;
    }
}

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;
    }
}

使用递归实现:

java 复制代码
public class InorderTraversal {

  public static void main(String[] args) {
    // 测试代码入口
    //创建测试数据 二叉树
    TreeNode treeNode = new TreeNode();
    treeNode = new TreeNode(1);
    treeNode.left = new TreeNode(2);
    treeNode.right = new TreeNode(3);
    System.out.println(inorderTraversal(treeNode));
  }
  //通过递归的方式来进行实现中序排序
  public static List<Integer> inorderTraversal(TreeNode root) {
    ArrayList<Integer> list = new ArrayList<>();
    dfs(list,root);
    return list;
  }
  public static void dfs(List<Integer> list ,TreeNode root){
    //如果为null则直接返回
    if(root  == null){
      return;
    }
    //遍历左子树
    dfs(list,root.left);
    //添加根
    list.add(root.val);
    //遍历右子树
    dfs(list,root.right);
  }
}

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;
  }
}
相关推荐
haogexiaole42 分钟前
Dijkstra 算法
算法
papership2 小时前
【入门级-算法-6、排序算法: 插入排序】
数据结构·算法·排序算法
HAH-HAH2 小时前
【蓝桥杯 2024 国 Java A】粉刷匠小蓝
c++·学习·数学·算法·职场和发展·蓝桥杯·组合数学
hweiyu003 小时前
C++设计模式,高级开发,算法原理实战,系统设计与实战(视频教程)
c++·算法·设计模式
大千AI助手4 小时前
粒子群优化(PSO)算法详解:从鸟群行为到强大优化工具
人工智能·算法·优化算法·pso·粒子群优化
我叫汪枫4 小时前
C语言深度入门系列:第十一篇 - 动态内存管理与数据结构:程序世界的高效算法大师
c语言·数据结构·算法
Li_7695324 小时前
优选算法100 题 ——1 双指针
算法
77qqqiqi4 小时前
算法——数学基础
算法
啊?啊?4 小时前
7 排序算法通关指南:从 O (n²)(选择 / 冒泡)到 O (nlogn)(快排 / 归并)+ 计数排序
数据结构·算法·排序算法
张较瘦_4 小时前
[论文阅读] 算法 | 抗量子+紧凑!SM3-OTS:基于国产哈希算法的一次签名新方案
论文阅读·算法·哈希算法