【算法二十四】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)

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

相关推荐
落羽的落羽10 分钟前
【项目】JsonRpc框架——开发实现1(细节功能、字段定义、抽象层、具象层)
linux·服务器·网络·c++·人工智能·算法·机器学习
handler0131 分钟前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集
qq7422349841 小时前
从“感知”到“决断”:测评百度伐谋产业决策智能体的端到端推理与行动机制
人工智能·算法·百度·大模型·运筹优化
huohaiyu2 小时前
深入解析Java垃圾回收机制
java·开发语言·算法·gc
浮芷.2 小时前
鸿蒙PC端 TTS 并发调用问题详解:资源竞争与队列管理
算法·华为·开源·harmonyos·鸿蒙·鸿蒙系统
装不满的克莱因瓶2 小时前
掌握感知器的学习原理
人工智能·python·神经网络·算法·ai·卷积神经网络
Lsk_Smion2 小时前
力扣实训 _ [994].腐烂的橘子/图论
算法·leetcode·图论
轻微的风格艾丝凡2 小时前
两电平三相VSC整流模式从不控整流平滑切换至有源整流调试记录
算法·dsp·c2000
dongf20192 小时前
R语言KNN算法
算法·数据分析·r语言
小O的算法实验室3 小时前
2025年IEEE TASE,基于双层耦合平均场博弈的大规模智能体集成任务分配与轨迹规划
人工智能·算法·机器学习