【算法二十四】101. 对称二叉树 543. 二叉树的直径

101. 对称二叉树

递归:

java 复制代码
class Solution {
    public boolean isSymmetric(TreeNode root) {
        return check(root.left,root.right);
    }

    public boolean check(TreeNode u,TreeNode v){
        if(u==null && v==null){
            return true;
        }

        if(u==null || v==null || u.val != v.val){
            return false;
        }

        return check(u.left,v.right) && check(u.right,v.left);
    }
}

时间复杂度:O(N)

空间复杂度:O(N)

迭代:

java 复制代码
class Solution {
    public boolean isSymmetric(TreeNode root) {
        return check(root, root);
    }

    public boolean check(TreeNode u, TreeNode v) {
        Queue<TreeNode> q = new LinkedList<TreeNode>();
        q.offer(u);
        q.offer(v);
        while (!q.isEmpty()) {
            u = q.poll();
            v = q.poll();
            if (u == null && v == null) {
                continue;
            }
            if ((u == null || v == null) || (u.val != v.val)) {
                return false;
            }

            q.offer(u.left);
            q.offer(v.right);

            q.offer(u.right);
            q.offer(v.left);
        }
        return true;
    }
}

时间复杂度:O(N)

空间复杂度:O(N)

核心:递归是递归函数本身,迭代是通过队列存储节点,注意ArrayDeque存储不了null,要用LinkedList来存储

543. 二叉树的直径

递归:

java 复制代码
 //拆分问题为母问题与子问题,找联系
 //求直径,其实就是求左子树最长值+右子树最长值
 //左子树最长值就是左子树下一个节点的最长值+1
class Solution {
    private int ans;
    public int diameterOfBinaryTree(TreeNode root) {
        int maxLen = simulate(root);
        return ans;
    }

    private int simulate(TreeNode root){
        if(root == null){
            return -1;
        }

        int lLen = simulate(root.left) + 1;
        int rLen = simulate(root.right) + 1;
        ans = Math.max(ans,lLen+rLen);
        return Math.max(lLen,rLen);
    }
}

时间复杂度:O(N)

空间复杂度:O(N)

递归:写终止条件,找逻辑,确保范围缩小

相关推荐
超级大只老咪几秒前
线性递推通用模板
java·开发语言·算法
17(无规则自律)1 分钟前
DFS:带重复项的全排列,程序运行全流程解析
c++·算法·深度优先
AI棒棒牛8 分钟前
SCI核心论文剖析:ICSD-YOLO:面向工业现场安全的实时智能检测算法
算法·yolo·目标检测·计算机视觉·目标跟踪·yolo26
郝学胜-神的一滴12 分钟前
「栈与缩点的艺术」二叉树前序序列化合法性判定:从脑筋急转弯到工程实现
java·开发语言·数据结构·c++·python·算法
汀、人工智能34 分钟前
[特殊字符] 第25课:合并两个有序链表
数据结构·算法·链表·数据库架构··合并两个有序链表
Khsc434ka38 分钟前
LeetCode-001:Python 实现哈希表求两数之和:初识哈希表
python·leetcode·散列表
Hello.Reader39 分钟前
双卡 A100 + Ollama 生产部署从安装、踩坑、调优到最终可上线方案
linux·人工智能·算法
计算机安禾39 分钟前
【数据结构与算法】第30篇:哈希表(Hash Table)
数据结构·学习·算法·哈希算法·散列表·visual studio
xiaoye-duck40 分钟前
《算法题讲解指南:动态规划算法--子序列问题(附总结)》--32.最长的斐波那契子序列的长度,33.最长等差数列,34.等差数列划分II-子序列
c++·算法·动态规划