leetcode-13-[110]平衡二叉树[257]二叉树的所有路径[404]左叶子之和[222]完全二叉树的节点个数

本文主要是介绍leetcode-13-[110]平衡二叉树[257]二叉树的所有路径[404]左叶子之和[222]完全二叉树的节点个数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、[110]平衡二叉树

注意:注释的1、2两处得有返回值-1

class Solution {public boolean isBalanced(TreeNode root) {int result = getHeight(root);return result != (-1);}//高度public int getHeight(TreeNode node){if(node==null){return 0;}int lh = getHeight(node.left);//注意1if(lh==-1){return -1;}int rh = getHeight(node.right);//注意2if(rh==-1){return -1;}if(Math.abs(lh-rh)>1){return -1;}return Math.max(lh,rh)+1;}
}

二、[257]二叉树的所有路径

class Solution {public List<String> binaryTreePaths(TreeNode root) {List<String> res=new ArrayList<>();List<Integer> path=new ArrayList<>();treePaths(root,res,path);return res;}void treePaths(TreeNode node,List<String> res,List<Integer> path){path.add(node.val);if(node.left==null&&node.right==null){String tmp="";for(int i=0;i< path.size()-1;i++){tmp+=path.get(i);tmp+="->";}tmp+=path.get(path.size()-1);res.add(tmp);}//注意不为空的判断if(node.left!=null) {treePaths(node.left, res, path);path.remove(path.size() - 1);}if(node.right!=null) {treePaths(node.right, res, path);path.remove(path.size() - 1);}}}

三、[404]左叶子之和

重点:注意不能直接返回 root.left.val,即它的if条件 不是 终止递归的条件

如:根节点的左子树,只有一个节点,符合条件,此时直接返回

而右子树还没有进行递归,解答错误。

应该暂存tmp=root.left.val,

在左右子树均进入递归后,再返回。

另:后序遍历 逻辑更加容易理解。

class Solution {public int sumOfLeftLeaves(TreeNode root) {if(root==null){return 0;}if(root.left==null&&root.right==null){return 0;}//防止出现根节点的左节点满足条件,就直接返回了,递归还没有进行//前序遍历//还有右子树没有遍历,不能直接returnint tmp=0;if(root.left!=null&&root.left.left==null&&root.left.right==null){tmp=root.left.val;}int lv = sumOfLeftLeaves(root.left);int rv = sumOfLeftLeaves(root.right);return lv+rv+tmp;//0+0+tmp//后序遍历
//        int lv = sumOfLeftLeaves(root.left);
//        int rv = sumOfLeftLeaves(root.right);
//        int tmp=0;
//        if(root.left!=null&&root.left.left==null&&root.left.right==null)
//        {
//              tmp=root.left.val;
//        }
//        return tmp+lv+rv;}
}

四、[222]完全二叉树的节点个数

class Solution {public int countNodes(TreeNode root) {if(root==null){return 0;}int ln = countNodes(root.left);int rn = countNodes(root.right);return ln+rn+1;}
}

这篇关于leetcode-13-[110]平衡二叉树[257]二叉树的所有路径[404]左叶子之和[222]完全二叉树的节点个数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1079025

相关文章

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓

Linux find 命令完全指南及核心用法

《Linuxfind命令完全指南及核心用法》find是Linux系统最强大的文件搜索工具,支持嵌套遍历、条件筛选、执行动作,下面给大家介绍Linuxfind命令完全指南,感兴趣的朋友一起看看吧... 目录一、基础搜索模式1. 按文件名搜索(精确/模糊匹配)2. 排除指定目录/文件二、根据文件类型筛选三、时间

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想

Python中Windows和macOS文件路径格式不一致的解决方法

《Python中Windows和macOS文件路径格式不一致的解决方法》在Python中,Windows和macOS的文件路径字符串格式不一致主要体现在路径分隔符上,这种差异可能导致跨平台代码在处理文... 目录方法 1:使用 os.path 模块方法 2:使用 pathlib 模块(推荐)方法 3:统一使

一文教你解决Python不支持中文路径的问题

《一文教你解决Python不支持中文路径的问题》Python是一种广泛使用的高级编程语言,然而在处理包含中文字符的文件路径时,Python有时会表现出一些不友好的行为,下面小编就来为大家介绍一下具体的... 目录问题背景解决方案1. 设置正确的文件编码2. 使用pathlib模块3. 转换路径为Unicod

JavaScript中的Map用法完全指南

《JavaScript中的Map用法完全指南》:本文主要介绍JavaScript中Map用法的相关资料,通过实例讲解了Map的创建、常用方法和迭代方式,还探讨了Map与对象的区别,并通过一个例子展... 目录引言1. 创建 Map2. Map 和对象的对比3. Map 的常用方法3.1 set(key, v

MySQL9.0默认路径安装下重置root密码

《MySQL9.0默认路径安装下重置root密码》本文主要介绍了MySQL9.0默认路径安装下重置root密码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录问题描述环境描述解决方法正常模式下修改密码报错原因问题描述mysqlChina编程采用默认安装路径,

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤