二叉树及leetcode练习题
时间:2022-07-28
本文章向大家介绍二叉树及leetcode练习题,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
二叉树
二叉树天然的递归结构
二叉树本身就是一个递归的定义。先来看一下递归的前序遍历:
void preorder(TreeNode* node) {
if (node) {
cout<<node->val;
preorder(node->left);
prorder(node->right);
}
}
递归的定义:递归终止条件 + 递归过程
- 前序遍历
void preorder(TreeNode* node) {
// 递归终止条件
if(node == NULL)
return;
cout << node->val;
// 递归过程
preorder(node->left);
preorder(node->right);
}
二叉树的递归定义:空也是一个二叉树
- 查看是否存在某个节点
bool contain(Node* node, Key key) {
if( node == NULL )
return false;
if( key == node->key )
return true;
if( contain(node->left, key) || contain(node->right, key) )
return true;
return false;
}
- 删除节点
void destroy(Node* node) {
if( node == NULL )
return;
destroy(node->left);
destroy(node->right);
delete node;
count--;
}
104. 二叉树的最大深度
定一个二叉树,找出其最大深度。
二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。
说明: 叶子节点是指没有子节点的节点。
示例:
给定二叉树 [3,9,20,null,null,15,7]
,
3
/
9 20
/
15 7
返回它的最大深度 3 。
c++代码
// @lc code=start
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
int maxDepth(TreeNode* root) {
if ( root == NULL ) {
return 0;
}
int leftMaxDepth = maxDepth( root-> left);
int rightMaxDepth = maxDepth( root-> right);
return max(leftMaxDepth, rightMaxDepth) + 1;
}
};
// @lc code=end
111. 二叉树的最小深度
给定一个二叉树,找出其最小深度。
最小深度是从根节点到最近叶子节点的最短路径上的节点数量。
说明: 叶子节点是指没有子节点的节点。
示例:
给定二叉树 [3,9,20,null,null,15,7]
,
3
/
9 20
/
15 7
返回它的最小深度 2.
c++题解
class Solution {
public:
int minDepth(TreeNode* root) {
if ( root == NULL)
return 0;
int leftMinDepth = minDepth(root->left);
int rightMinDepth = minDepth(root->right);
return 1 + (min(leftMinDepth, rightMinDepth) ? min(leftMinDepth, rightMinDepth) : max(leftMinDepth, rightMinDepth));
}
};
225. 翻转二叉树
翻转一棵二叉树。
示例:
输入:
4
/
2 7
/ /
1 3 6 9
输出:
4
/
7 2
/ /
9 6 3 1
备注: 这个问题是受到 Max Howell 的 原问题 启发的 :
谷歌:我们90%的工程师使用您编写的软件(Homebrew),但是您却无法在面试时在白板上写出翻转二叉树这道题,这太糟糕了。
c++题解
class Solution {
public:
TreeNode* invertTree(TreeNode* root) {
if (root == NULL) {
return NULL;
}
invertTree( root-> left);
invertTree( root-> right);
swap(root->left, root->right);
return root;
}
};
100. Same Tree
101. Symmetric Tree
222. Count Complete Tree Nodes
- 利用Geneva开发SOA的安全模型
- STOMP协议介绍
- ADO.NET实体框架连接串引发的异常:Unable to load the specified metadata resource
- Mono产品生命周期
- WordPress免插件仅代码实现文章归档模板 II
- Paket 介绍
- C语言学不会,编程能力无法提升?你的问题我来解决!
- 实现WCF和Unity 的集成
- Qt中纯C++项目发布为dll的方法(超详细步骤)
- .NET的Actor模型:Orleans
- UML:类图复习-鸡生蛋,蛋生鸡
- DotNet多个程序集合并工具
- Spring官网下载dist.zip的几种方法
- Spring Security笔记:HTTP Basic 认证
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Android Studio实现标题栏和状态栏的隐藏
- Android实现手电筒电源键关闭功能
- Android实现保持屏幕常亮功能
- Android开发实现的几何图形工具类GeometryUtil完整实例
- Android自定义View倒计时圆
- Android开发实现的IntentUtil跳转多功能工具类
- Android端“被挤下线”功能的单点登录实现
- Android轻松实现多语言的方法示例
- Android开发实现去除bitmap无用白色边框的方法示例
- Android开发实现的内存管理工具类
- Android日期和时间选择器实现代码
- Android开发实现ImageView加载摄像头拍摄的大图功能
- Android开发实现的Intent跳转工具类实例
- Android开发中的文件操作工具类FileUtil完整实例
- Android开发中超好用的正则表达式工具类RegexUtil完整实例