LeetCode 刷题【103. 二叉树的锯齿形层序遍历、104. 二叉树的最大深度、105. 从前序与中序遍历序列构造二叉树】

103. 二叉树的锯齿形层序遍历

自己做

解:先序遍历

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 {
    List<List<Integer>> res = new ArrayList();
    public void preTravelTree(TreeNode root, int level){
        if(root == null)
            return;
        
        if(res.size() == level){                //添加列表【新的一层】
            List<Integer> new_level = new ArrayList();
            new_level.add(root.val);
            res.add(new_level);
        }
        else{                                   //已有列表
            List<Integer> old_level = res.get(level);
            if(level % 2 == 1){                 //奇数层,头插
                old_level.addFirst(root.val);
            }
            else{                               //偶数层,尾插
                old_level.addLast(root.val);
            }
        }

        preTravelTree(root.left, level + 1);
        preTravelTree(root.right, level + 1);
    }


    public List<List<Integer>> zigzagLevelOrder(TreeNode root) {
        preTravelTree(root, 0);
        return res;
    }
}

104. 二叉树的最大深度

自己做

解:先序遍历

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 {
    private int min_level = 0;

    public void preTravelTree(TreeNode root, int level){
        if(root == null)
            return;

        if(level > min_level)
            min_level = level;

        preTravelTree(root.left, level + 1);
        preTravelTree(root.right, level + 1);
    }

    public int maxDepth(TreeNode root) {
        preTravelTree(root, 1);
        return min_level;
    }
}

105. 从前序与中序遍历序列构造二叉树

自己做

解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 {
    private int i = 0;

    public TreeNode inorderTravel(int[] preorder, int[] inorder, int begin, int end){
        if(begin > end)                                                         //到底了
            return null;

        TreeNode root = new TreeNode(preorder[i++]);                            //当前结点
        
        int mid = begin;                                                        //记录划分位置
        for(int j = begin; j <= end && preorder[i - 1] != inorder[mid]; j++)    //找划分位置
            mid++;

        TreeNode left = inorderTravel(preorder, inorder, begin, mid - 1);      //左子树
        TreeNode right = inorderTravel(preorder, inorder, mid + 1, end);       //右子树
        root.left = left;
        root.right =right;

        return root;
    }

    public TreeNode buildTree(int[] preorder, int[] inorder) {
        return inorderTravel(preorder, inorder, 0, preorder.length - 1);
    }
}

解2:哈希集合版

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 {
    private int i = 0;
    Map<Integer, Integer> m = new HashMap();                                     //构建键值对集合

    public TreeNode inorderTravel(int[] preorder, int[] inorder, int begin, int end){
        if(begin > end)                                                         //到底了
            return null;

        int mid = m.get(preorder[i]);                                           //获得分割点
        TreeNode root = new TreeNode(preorder[i++]);                            //当前结点
        TreeNode left = inorderTravel(preorder, inorder, begin, mid - 1);       //左子树
        TreeNode right = inorderTravel(preorder, inorder, mid + 1, end);        //右子树
        root.left = left;
        root.right =right;

        return root;
    }

    public TreeNode buildTree(int[] preorder, int[] inorder) {
        for(int i = 0; i < preorder.length; i++)
            m.put(preorder[i], 0);
        for(int i = 0; i < preorder.length; i++)
            m.put(inorder[i], i);
        
        return inorderTravel(preorder, inorder, 0, preorder.length - 1);
    }
}
相关推荐
深邃-21 小时前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
We་ct1 天前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
王老师青少年编程1 天前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮1 天前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说1 天前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove1 天前
关于算法设计中的代价函数优化与约束求解的技术7
算法
小程故事多_801 天前
[大模型面试系列] 多轮对话 Agent 设计实战(含窗口优化 + 工具调用精髓)
人工智能·面试·职场和发展
leoufung1 天前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了1 天前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL1 天前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化