leetcode-----二叉树习题

 目录

前言

1. 二叉树的中序遍历

2. 相同的树

3. 二叉树的最大深度

4. 二叉树的最小深度

5.二叉树的前序遍历

6. 二叉树的后序遍历

7. 对称二叉树


前言

        前面我们学习过了二叉树的相关知识点,那么今天我们就做做练习,下面我会介绍几道关于二叉树的leetcode习题,我们一起来看看吧!

二叉树相关链接:

二叉树的基本操作:数据结构-----二叉树的基本操作-CSDN博客

二叉树的创建和遍历:数据结构-----二叉树的创建和遍历-CSDN博客

二叉树的基础知识点:数据结构-----树和二叉树必知必会知识_Gretel Tade的博客-CSDN博客

堆的相关方法代码实现:数据结构-----堆(完全二叉树)-CSDN博客

1. 二叉树的中序遍历

 给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。

思路分析:

 这道题是这样要求的,给入一个int类型的指针num,要求去进行动态空间的分配为数组,然后去进行中序遍历二叉树节点,把得到的数据存入到这个数组里面去,最后输出这个数组,也就是说中序遍历的同时还会去拿到数据进行储存。

 代码实现:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/void travel(struct TreeNode* root, int*num,int*returnSize){if(!root)return;travel(root->left,num,returnSize);num[*returnSize]=root->val;*returnSize+=1;travel(root->right,num,returnSize);
}
/*** Note: The returned array must be malloced, assume caller calls free().*/
int* inorderTraversal(struct TreeNode* root, int* returnSize){int* num=(int*)malloc(sizeof(int)*100);*returnSize=0;if(!root)return NULL;travel(root,num,returnSize);return num;}


2. 相同的树

给你两棵二叉树的根节点 p 和 q ,编写一个函数来检验这两棵树是否相同。

如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。

思路分析:

 要判断是否相同的树,就要判断同一个位置的节点是否存在,存在的同时里面的值是否相同,那就分以下三种情况。第一:节点都不存在,那么这就是满足条件true;第二:一个节点存在一个不存在,那就是false;第三:里面的值不同,结果还是false。对以上的三种情况进行左子树和右子树遍历取和运算即可。

代码实现:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/
bool isSameTree(struct TreeNode* p, struct TreeNode* q){if(!p&&!q)return true;if(!p||!q)return false;if(p->val!=q->val)return false;return isSameTree(p->left,q->left) && isSameTree(p->right,q->right);
}

3. 二叉树的最大深度

给定一个二叉树 root ,返回其最大深度。

二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。

思路分析:

获取最大深度,那就是每次向左右子树进行遍历,取每次遍历一层就进行深度+1,最后递归到根节点的时候,比较此时左右子树当前深度的大小,取其中大的一个返回即可。

 代码实现:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/int maxDepth(struct TreeNode* root){if(!root){return 0;}int l=maxDepth(root->left);int r=maxDepth(root->right);if(l>r)return l+1;elsereturn r+1;
}

4. 二叉树的最小深度

给定一个二叉树,找出其最小深度。

最小深度是从根节点到最近叶子节点的最短路径上的节点数量。

说明:叶子节点是指没有子节点的节点。

思路分析:

跟上面求最大深度不同,这里就要去分三种情况来讨论了,首先就是如果这个树只有右子树没有左子树,那么返回的值就是从右子树遍历的结果;如果只有左子树没有右子树,那么返回的深度也就是左子树遍历的结果,如果左右子树都有的话,那么返回的深度就是其中较小者的值。

代码实现:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/
int minDepth(struct TreeNode* root){if(!root){return 0;
}else if(!root->left&&root->right)return minDepth(root->right)+1;else if(!root->right&&root->left)return minDepth(root->left)+1;else {int l=minDepth(root->left);int r= minDepth(root->right);if(l>r)return r+1;elsereturn l+1;}
}


5.二叉树的前序遍历

给你二叉树的根节点 root ,返回它节点值的 前序 遍历。 

思路分析:

跟中序遍历是一样的,先进行分配储存数据的数组空间,然后进入到前序遍历的过程中,一边储存数据,一边遍历,最后的遍历结果就是直接输出这个数组储存到的数据即可。

 代码实现:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/
/*** Note: The returned array must be malloced, assume caller calls free().*/
void travel(struct TreeNode* root, int *num,int* returnSize)
{if(!root)return;num[*returnSize]=root->val;*returnSize+=1;travel(root->left,num,returnSize);travel(root->right,num,returnSize);
}
int* preorderTraversal(struct TreeNode* root, int* returnSize){int* num=(int*)malloc(sizeof(int)*100);*returnSize=0;travel(root,num,returnSize);return num;}


6. 二叉树的后序遍历

给你一棵二叉树的根节点 root ,返回其节点值的 后序遍历 。 

思路分析:

方法还是跟上面一样的,通过分配储存数据数组的空间来储存当前后序遍历的结果。

 代码实现:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*//*** Note: The returned array must be malloced, assume caller calls free().*/void travel(struct TreeNode* root, int *num,int* returnSize)
{if(!root)return;travel(root->left,num,returnSize);travel(root->right,num,returnSize);num[*returnSize]=root->val;*returnSize+=1;
}
int* postorderTraversal(struct TreeNode* root, int* returnSize){int *num=(int*)malloc(sizeof(int)*500);*returnSize=0;travel(root,num,returnSize);return num;
}


7. 对称二叉树

给你一个二叉树的根节点 root , 检查它是否轴对称。

思路分析:

判断一个二叉树是否为对称二叉树也就是以根结点为对称轴进行划分比较,同样的分一些几种情况去讨论。1.如果此时对称位置的节点都为空,那么结果就是true;2.如果对称位置节点一个为空一个不为空,那结果就是false;3.如果对称位置节点的值不同,那结果也是false;4.最后就是如果对称位置的节点都存在而且里面的数据值也是相同的,那么就进行往下遍历,最后进行取和运算结果即可。

代码实现:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/bool check(struct TreeNode* p,struct TreeNode* q){if(!p&&!q)return true;if(p==NULL||!q)return false;if(p->val!=q->val)return false;elsereturn check(p->left,q->right)&&check(p->right,q->left);
}
bool isSymmetric(struct TreeNode* root){return check(root,root);
}

 好了,以上就是本期习题的全部内容了,我们下一期再见!

 分享一张壁纸:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/145761.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

JUnit介绍

JUnit是用于编写和运行可重复的自动化测试的开源测试框架, 这样可以保证我们的代码按预期工作。JUnit可广泛用于工业和作为支架(从命令行)或IDE(如Eclipse)内单独的Java程序。 JUnit提供: 断言测试预期结果。 测试功能共享通用的测试数据。 测试套件轻…

Java实现word excel ppt模板渲染与导出及预览 LibreOffice jodconverter

Java Office 一、文档格式转换 文档格式转换是office操作中经常需要进行一个操作,例如将docx文档转换成pdf格式。 java在这方面有许多的操作方式,大致可以分为内部调用(无需要安装额外软件),外部调用(需…

STM32三种开发方式及标准库和HAL库的编程差异

三种开发方式 STM32基于标准库函数和HAL库编程差异_stm32库函数和hal库-CSDN博客本文目的是以串口通信来简要分析STM32使用标准库函数和HAL库函数编程的差异。目录(一)开发方式1.配置寄存器2.库函数3.HAL库(二)库函数与HAL库对比…

RDMA技术(解决主从数据库数据不一致问题)

优质博文:IT-BLOG-CN 一、简介 RDMA(remote direct memory access)即远端直接内存访问,是一种高性能网络通信技术,具有高带宽、低延迟、无CPU消耗等优点。 主要解决网络传输中服务器端数据处理的延迟问题。 Remote:数据通过网络…

Arduino PLC IDE

Arduino PLC IDE MCU单片机进入全新的PLC领域概述需要的硬件和软件下一步操作1. Arduino PLC IDE Tool Setup2. Arduino PLC IDE Setup3. Project Setup4. Download the Runtime5. Connect to the Device6. License Activation with Product Key (Portenta Machine Control) 结…

MySQL 索引介绍和最佳实践

目录 一、前言二、索引类型1.1 主键索引(PRIMARY KEY)1.2 唯一索引(UNIQUE)1.3 普通索引(NORMAL)1.3.1 单列普通索引1.3.2 单列前缀普通索引1.3.3 多列普通索引1.3.4 多列前缀普通索引 1.4 空间索引&#x…

力扣 -- 10. 正则表达式匹配

解题步骤&#xff1a; 参考代码&#xff1a; class Solution { public:bool isMatch(string s, string p) {int ms.size();int np.size();//处理后续映射关系s s;//处理后续映射关系p p;vector<vector<bool>> dp(m1,vector<bool>(n1));//初始化dp[0][0]true…

WPF 03

staticResource和dynamicResource的区别 首先看一个案例 MainWindow.xaml <Window x:Class"WpfDay03.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/2006/xaml&quo…

led灯什么牌子的质量好?Led护眼台灯排行榜

现在我们很多家长对自己孩子的视力十分关心&#xff0c;生怕自己的孩子是近视、远视、弱视等等。对于父母而言&#xff0c;在孩子读书压力大课业重的关键时期&#xff0c;为孩子选择合适的桌椅&#xff0c;保护灯具从而保护孩子的眼睛是非常重要的事情!那么买给孩子读书做功课的…

驱动插入中断门示例代码

驱动插入中断描述符示例代码 最近做实验&#xff0c;每次在应用层代码写测试代码的时候都要手动挂一个中断描述符&#xff0c;很不方便所以就想着写个驱动挂一个中断门比较省事 驱动测试效果如下&#xff1a; 下面的代码是个架子&#xff0c;用的时候找个驱动历程传递你要插…

聊聊并发编程——并发容器和阻塞队列

目录 一.ConcurrentHashMap 1.为什么要使用ConcurrentHashMap&#xff1f; 2.ConcurrentHashMap的类图 3.ConcurrentHashMap的结构图 二.阻塞队列 Java中的7个阻塞队列 ArrayBlockingQueue&#xff1a;一个由数组结构组成的有界阻塞队列。 LinkedBlockingQueue&#xf…

如何快速搭建app自动化环境编写用例?

使用Airtest 作为测试开发工程师&#xff0c;快速搭建app自动化环境并编写用例可以使用Airtest解决方案来实现。Airtest是一款基于Python的全平台UI自动化测试框架&#xff0c;支持多种移动设备和模拟器&#xff0c;同时集成了丰富的图像识别和手势操作功能。 以下是使用Airt…

【0223】源码剖析smgr底层设计机制(3)

1. smgr设计机制 PG内核中smgr完整磁盘存储介质的管理是通过下面三部分实现的。 1.1 函数指针结构体 f_smgr 函数指针结构体 f_smgr。 通过该函数指针类型,可完成类似于UNIX系统中的VFD功能,上层只需要调用open()、read()、write()等系统函数,用户不必去关系底层的文件系统…

【我的创作纪念日】使用pix2pixgan实现barts2020数据集的处理(完整版本)

使用pix2pixgan &#xff08;pytorch)实现T1 -> T2的基本代码 使用 https://github.com/eriklindernoren/PyTorch-GAN/ 这里面的pix2pixgan代码进行实现。 进去之后我们需要重新处理数据集&#xff0c;并且源代码里面先训练的生成器&#xff0c;后训练鉴别器。 一般情况下…

数据结构之单链表

首先我们要分析为什么要链表 那么我们就要先分析顺序表的优缺点 首先我们要确定链表的结构是一个数据存放的空间&#xff0c;指向下个结点的指针域 然后我们实现打印和创建新的节点 然后我们实现头插和尾插 这个地方有一个易错点 首先对尾插来说&#xff0c;如果我们插入的是…

国庆《乡村振兴战略下传统村落文化旅游设计》许少辉八一新书行将售罄

国庆《乡村振兴战略下传统村落文化旅游设计》许少辉八一新书行将售罄 国庆《乡村振兴战略下传统村落文化旅游设计》许少辉八一新书行将售罄

Vue之transition组件

Vue提供了transition组件&#xff0c;使用户可以更便捷地添加过渡动画效果。 transition组件 transition组件也是一个抽象组件&#xff0c;并不会渲染出真实dom。Vue会在其第一个真实子元素上添加过渡效果。 props render 这里将render分为两部分&#xff0c;第一部分界定真…

【模板语法+数据绑定+el与data的两种写法+MVVM模型】

模板语法数据绑定el与data的两种写法MVVM模型 1 模板语法1.1 插值语法1.2 指令语法 2 数据绑定2.1 单向数据绑定2.2 双向数据绑定 3 el与data的两种写法4 MVVM模型 1 模板语法 1.1 插值语法 双大括号表达式功能&#xff1a;用于解析标签体内容语法&#xff1a;{{xxx}}&#x…

Firecamp2.7.1exe安装与工具调试向后端发送SocketIO请求

背景&#xff1a; 笔者在python使用socket-io包时需要一个测试工具&#xff0c;选择了firecamp这个测试工具来发送请求。 参考视频与exe资源包&#xff1a; Firecamp2.7.1exe安装包以及基本使用说明文档&#xff08;以SocketIO为例&#xff09;.zip资源-CSDN文库 15_send方法…

论文笔记(整理):轨迹相似度顶会论文中使用的数据集

0 汇总 数据类型数据名称数据处理出租车数据波尔图 原始数据&#xff1a;2013年7月到2014年6月&#xff0c;170万条数据 ICDE 2023 Contrastive Trajectory Similarity Learning with Dual-Feature Attention 过滤位于城市&#xff08;或国家&#xff09;区域之外的轨迹 过…