代码随想录算法训练营第十五天| 110.平衡二叉树、257. 二叉树的所有路径、404.左叶子之和、 222.完全二叉树的节点个数

本文主要是介绍代码随想录算法训练营第十五天| 110.平衡二叉树、257. 二叉树的所有路径、404.左叶子之和、 222.完全二叉树的节点个数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Leetcode110.平衡二叉树

题目链接:110. 平衡二叉树

C++:(后序遍历)

class Solution {
public:int getheight(TreeNode *node){if(node == nullptr) return 0;//左int leftheight = getheight(node->left);if(leftheight == -1) return -1;//右int rightheight = getheight(node->right);if(rightheight == -1) return -1;//中int result;if(abs(leftheight - rightheight) > 1)result = -1;else{result = 1 + max(leftheight, rightheight);}return result;}bool isBalanced(TreeNode* root) {return getheight(root) == -1 ? false : true;}
};

Python:

class Solution:def getheight(self, node):if node == None:return 0leftheight = self.getheight(node.left)if leftheight == -1:return -1rightheight = self.getheight(node.right)if rightheight == -1:return -1if abs(leftheight - rightheight) > 1:result = -1else:result = 1 + max(leftheight, rightheight)return resultdef isBalanced(self, root: Optional[TreeNode]) -> bool:return False if self.getheight(root) == -1 else True

Leetcode257. 二叉树的所有路径

题目链接:257. 二叉树的所有路径

C++:(回溯算法初体验)

注意:传入的形参为引用格式,递归+回溯成对出现

class Solution {
public:void findway(TreeNode* node, vector<int> &path, vector<string> &result){//中path.push_back(node->val);if(node->left == nullptr && node->right == nullptr){string sPath;for(int i=0; i < path.size() - 1; i++){sPath += to_string(path[i]);sPath += "->";}sPath += to_string(path[path.size() - 1]);result.push_back(sPath);return;}//左if(node->left != nullptr){findway(node->left, path, result);path.pop_back();  //回溯}//右if(node->right != nullptr){findway(node->right, path, result);path.pop_back();  //回溯}}vector<string> binaryTreePaths(TreeNode* root) {vector<string> result;vector<int> path;if (root == NULL) return result;findway(root, path, result);return result;}
};

Python:

map()函数:会根据提供的函数对指定序列做映射,语法:map(function, iterable)

     (1)function:函数

       (2) iterable:一个或多个序列

class Solution:def findway(self, node, path, result):# zhongpath.append(node.val)if node.left == None and node.right == None:sPath = '->'.join(map(str, path))result.append(sPath)returnif node.left:self.findway(node.left, path, result)path.pop()if node.right:self.findway(node.right, path, result)path.pop()def binaryTreePaths(self, root: Optional[TreeNode]) -> List[str]:path = []result = []if root == None:return resultself.findway(root, path, result)return result

Leetcode404.左叶子之和

题目链接:404. 左叶子之和

C++:

class Solution {
public:int sumOfLeftLeaves(TreeNode* root) {if(root == nullptr) return 0;if(root->left == nullptr && root->right == nullptr) return 0;//zuoint Leftsum = sumOfLeftLeaves(root->left);if(root->left != nullptr && root->left->left == nullptr && root->left->right == nullptr)Leftsum = root->left->val;//youint Rightsum = sumOfLeftLeaves(root->right);//zhongint sum = Leftsum + Rightsum;return sum;}
};

Leetcode 222.完全二叉树的节点个数

题目链接:222. 完全二叉树的节点个数

完全二叉树的结点数量可以通过满二叉树结点数量公式计算:2**depth - 1

C++:

class Solution {
public:int countNodes(TreeNode* root) {//后序遍历if(root == nullptr) return 0;auto left = root->left;int leftdepth = 0;auto right = root->right;int rightdepth = 0;while(left){left = left->left;leftdepth++;}while(right){right = right->right;rightdepth++;}if(leftdepth == rightdepth)return (2 << leftdepth) - 1;//zuoint leftnum = countNodes(root->left);//youint rightnum = countNodes(root->right);//zhongint num = leftnum + rightnum + 1;return num;}
};

这篇关于代码随想录算法训练营第十五天| 110.平衡二叉树、257. 二叉树的所有路径、404.左叶子之和、 222.完全二叉树的节点个数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

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

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

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

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

Java中&和&&以及|和||的区别、应用场景和代码示例

《Java中&和&&以及|和||的区别、应用场景和代码示例》:本文主要介绍Java中的逻辑运算符&、&&、|和||的区别,包括它们在布尔和整数类型上的应用,文中通过代码介绍的非常详细,需要的朋友可... 目录前言1. & 和 &&代码示例2. | 和 ||代码示例3. 为什么要使用 & 和 | 而不是总是使

Java强制转化示例代码详解

《Java强制转化示例代码详解》:本文主要介绍Java编程语言中的类型转换,包括基本类型之间的强制类型转换和引用类型的强制类型转换,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录引入基本类型强制转换1.数字之间2.数字字符之间引入引用类型的强制转换总结引入在Java编程语言中,类型转换(无论

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

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

Vue 调用摄像头扫描条码功能实现代码

《Vue调用摄像头扫描条码功能实现代码》本文介绍了如何使用Vue.js和jsQR库来实现调用摄像头并扫描条码的功能,通过安装依赖、获取摄像头视频流、解析条码等步骤,实现了从开始扫描到停止扫描的完整流... 目录实现步骤:代码实现1. 安装依赖2. vue 页面代码功能说明注意事项以下是一个基于 Vue.js

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

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

mybatis-plus 实现查询表名动态修改的示例代码

《mybatis-plus实现查询表名动态修改的示例代码》通过MyBatis-Plus实现表名的动态替换,根据配置或入参选择不同的表,本文主要介绍了mybatis-plus实现查询表名动态修改的示... 目录实现数据库初始化依赖包配置读取类设置 myBATis-plus 插件测试通过 mybatis-plu