算法工程题(中序遍历)

复制代码
*  题意说明:
*  给定一个二叉树的根节点 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;
  }
}
相关推荐
Yupureki几秒前
《算法竞赛从入门到国奖》算法基础:动态规划-路径dp
数据结构·c++·算法·动态规划
副露のmagic29 分钟前
数组章节 leetcode 思路&实现
算法·leetcode·职场和发展
荣光属于凯撒32 分钟前
P2176 [USACO11DEC] RoadBlock S / [USACO14FEB] Roadblock G/S
算法·图论
雨季mo浅忆1 小时前
记录利用Cursor快速实现拖拽式问卷题型创建
算法
Yzzz-F1 小时前
2018-2019 ACM-ICPC, Asia Dhaka Regional ContestC[数论]
算法
Frostnova丶1 小时前
LeetCode 3474. 字典序最小的生成字符串
算法·leetcode·职场和发展
REDcker1 小时前
Nagle 算法与 TCP_NODELAY、TCP_CORK 详解
网络·tcp/ip·算法
β添砖java1 小时前
深度优先搜索DFS
算法·深度优先
小糯米6011 小时前
C++ 并查集
java·c++·算法
IronMurphy1 小时前
【算法三十四】39. 组合总和
算法·深度优先