算法工程题(中序遍历)

复制代码
*  题意说明:
*  给定一个二叉树的根节点 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;
  }
}
相关推荐
吃个糖糖20 分钟前
4.PCL点云的数据结构
数据结构·算法
MyOaSis21 分钟前
拆解并实现KMP算法
算法
用户403159863966327 分钟前
字符串原地排序
java·算法
Du_XiaoNan34 分钟前
Java并发第一篇(从零开始:一文读懂Java并发编程核心基础)
java·前端·算法
weixin_4786897639 分钟前
【从树的视角理解递归】【递归 = 遍历 || 分解】
算法
小指纹1 小时前
初识 二叉树
c++·算法·二叉树·
CoovallyAIHub2 小时前
YOLO11 vs LMWP-YOLO:参数量-52.5%,mAP+22.07%,小型无人机的远距离检测
深度学习·算法·计算机视觉
地平线开发者2 小时前
【理想汽车智驾方案介绍专题 -1】端到端+VLM 方案介绍
算法·自动驾驶·汽车
KyollBM2 小时前
【Luogu】每日一题——Day4. P5804 [SEERC 2019] Absolute Game (思维 博弈论)
数据结构·c++·算法
君莫默2 小时前
代码随想录-250716-图的读入与构建
数据结构·算法