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);
};
相关推荐
仰泳的熊猫38 分钟前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
似水明俊德4 小时前
02-C#.Net-反射-面试题
开发语言·面试·职场和发展·c#·.net
无极低码4 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
软件算法开发4 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
superior tigre5 小时前
22 括号生成
算法·深度优先
腾阳6 小时前
99%的人忽视了这一点:活着本身就是人生的意义,别让抑郁和内耗成为你的枷锁!
经验分享·程序人生·职场和发展·跳槽·学习方法·媒体
不吃西红柿的856 小时前
[职场] 内容运营求职简历范文 #笔记#职场发展
笔记·职场和发展·内容运营
liyang_8306 小时前
邦芒秘诀:职场高手都具备的三个特征
职场和发展
普通网友6 小时前
十大秘闻:揭秘霍兰德职业兴趣理论的未知面!
职场和发展·求职招聘·职场发展·单一职责原则