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);
    }
}
相关推荐
Cx330❀7 小时前
【优选算法必刷100题】第43题(模拟):数青蛙
c++·算法·leetcode·面试
杜子不疼.7 小时前
【LeetCode30_滑动窗口 + 哈希表】:三招搞定“串联所有单词的子串”
数据结构·算法·哈希算法
闻缺陷则喜何志丹7 小时前
【C++动态规划 状压dp】1879. 两个数组最小的异或值之和|2145
c++·算法·动态规划·力扣·数组·最小·动态规范
艾莉丝努力练剑7 小时前
【优选算法必刷100题:专题五】(位运算算法)第033~38题:判断字符是否唯一、丢失的数字、两整数之和、只出现一次的数字 II、消失的两个数字
java·大数据·运维·c++·人工智能·算法·位运算
光羽隹衡7 小时前
机器学习——DBSCAN算法
人工智能·算法·机器学习
vyuvyucd7 小时前
Java数组与Arrays类实战指南
数据结构·算法
csuzhucong7 小时前
七彩鹦鹉螺魔方
算法
逝川长叹7 小时前
利用 SSI-COV 算法自动识别线状结构在环境振动下的模态参数研究(Matlab代码实现)
前端·算法·支持向量机·matlab
山上三树7 小时前
详细介绍 C 语言中的匿名结构体
c语言·开发语言·算法
EXtreme357 小时前
【数据结构】彻底搞懂二叉树:四种遍历逻辑、经典OJ题与递归性能全解析
c语言·数据结构·算法·二叉树·递归