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);
};
相关推荐
WYiQIU1 小时前
普及一下字节前端岗需要达到的强度......
前端·javascript·vue.js·面试·职场和发展
测试19981 小时前
2026最新软件测试面试八股文(含答案+文档)
自动化测试·软件测试·功能测试·测试工具·面试·职场和发展·测试用例
老鼠只爱大米1 小时前
LeetCode经典算法面试题 #2:两数相加(迭代法、字符串修改法等多种实现方案详解)
算法·leetcode·链表·两数相加·字符串修改法·两数相减·大数运算
季明洵2 小时前
二分搜索、移除元素、有序数组的平方、长度最小的子数组
java·数据结构·算法·leetcode
Sheep Shaun2 小时前
深入理解AVL树:从概念到完整C++实现详解
服务器·开发语言·数据结构·c++·后端·算法
_leoatliang2 小时前
基于Python的深度学习以及常用环境测试案例
linux·开发语言·人工智能·python·深度学习·算法·ubuntu
启芯硬件2 小时前
三极管和MOS管的降额使用设计实战
大数据·人工智能·经验分享·职场和发展·硬件工程
leiming62 小时前
C语言联合体union的用法(非常详细,附带示例)
java·python·算法
YuTaoShao2 小时前
【LeetCode 每日一题】3314. 构造最小位运算数组 I —— (解法二)
算法·leetcode·职场和发展