Leetcode 94. 二叉树的中序遍历 104. 二叉树的最大深度 226. 翻转二叉树 101. 对称二叉树 (Day 13)

都不是很难 写一起算了
94. 二叉树的中序遍历

javascript 复制代码
//递归
derTraversal = function(root) {
    const ans=[];
    var dfs=function(root){
        if(!root) return ;
        if(root.left) dfs(root.left);
        ans.push(root.val);
        dfs(root.right);
    }
    
    dfs(root);
    return ans;
};

//迭代
var inorderTraversal = function(root) {
    const ans=[];
    const stack=[];
    
    while(root||stack.length){
    while(root){
        stack.push(root);
        root=root.left;
    }
    if(stack.length){
        root=stack.pop();
        ans.push(root.val);
        root=root.right;
        }
    }
    return ans;
};

104. 二叉树的最大深度

javascript 复制代码
axDepth = function(root) {
    if(!root) return 0;
    const leftroot=maxDepth(root.left)+1;
    const rightroot=maxDepth(root.right)+1;
    return leftroot>=rightroot?leftroot:rightroot;
    
};

226. 翻转二叉树

javascript 复制代码
var invertTree = function(root) {
    if(root){
    [root.right,root.left]=[root.left,root.right];
    invertTree(root.left);
    invertTree(root.right);
    }
    return root;
};

101. 对称二叉树

javascript 复制代码
var isSymmetric = function(root) {
    if(!root) return true;
    var dfs=function(node1,node2){
        if(!node1&&!node2) return true;
        if(!node1||!node2) return false;
        if(node1.val!=node2.val) return false;
        return  dfs(node1.left,node2.right)&&
                dfs(node1.right,node2.left);
        };
    return dfs(root.left,root.right);
};

//简洁写法(灵神)
var isSymmetric = function(root) {
    function isSameTree(p, q) {
        if (p === null || q === null) {
            return p === q;
        }
        return p.val === q.val && isSameTree(p.left, q.right) && isSameTree(p.right, q.left);
    }
    return isSameTree(root.left, root.right);
};
相关推荐
happymaker06262 小时前
LeetCodeHot100——42.接雨水
算法
阿正的梦工坊3 小时前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
八解毒剂4 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
运行时记录4 小时前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
啦啦啦啦啦zzzz5 小时前
算法总结(二分查找、双指针)
c++·算法
qq_8573058195 小时前
python语法
开发语言·python·算法
DXM05215 小时前
第9期|从机器学习到深度学习:AI遥感解译的进化逻辑
人工智能·算法·计算机视觉
小蒋学算法6 小时前
算法-阶乘函数后K个零
算法
weixin_307779136 小时前
智能模拟数据生成平台:生成式AI合成数据技术重塑开发测试效能
人工智能·测试工具·算法·测试用例
羊羊小栈7 小时前
Uplift营销供应链协同决策系统(基于Uplift因果推断与运筹优化算法)
前端·人工智能·算法·毕业设计·大作业