算法工程题(中序遍历)

复制代码
*  题意说明:
*  给定一个二叉树的根节点 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;
  }
}
相关推荐
小O的算法实验室40 分钟前
2025年SEVE SCI2区,具有局部和全局参数自适应差分进化算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
LGL6030A5 小时前
算法题实战积累(3)——方块转换(C语言)
c语言·算法
一条星星鱼5 小时前
深度学习是如何收敛的?梯度下降算法原理详解
人工智能·深度学习·算法
长路归期无望8 小时前
C语言小白实现多功能计算器的艰难历程
c语言·开发语言·数据结构·笔记·学习·算法
MobotStone8 小时前
AI训练的悖论:为什么越追求准确率越会产生幻觉?
算法
怀旧,10 小时前
【C++】26. 智能指针
开发语言·c++·算法
Haooog10 小时前
654.最大二叉树(二叉树算法)
java·数据结构·算法·leetcode·二叉树
Swift社区10 小时前
LeetCode 392 判断子序列
算法·leetcode·职场和发展
芒果量化10 小时前
ML4T - 第7章第8节 利用LR预测股票价格走势Predicting stock price moves with Logistic Regression
算法·机器学习·线性回归
东方芷兰10 小时前
JavaWeb 课堂笔记 —— 20 SpringBootWeb案例 配置文件
java·开发语言·笔记·算法·log4j·intellij-idea·lua