【LeetCode】链式二叉树OJ题---C语言版

链式二叉树OJ题

  • 一、单值二叉树
    • (1)题目描述:
    • (2)思路表述:
    • (3)代码实现:
  • 二、二叉树最大深度
    • (1)题目描述:
    • (2)思路表述:
    • (3)代码实现:
  • 三、检查两颗树是否相同
    • (1)题目描述:
    • (2)思路表述:
    • (3)代码实现:
  • 四、二叉树的前序遍历
    • (1)题目描述:
    • (2)思路表述:
    • (3)代码实现:
  • 五、翻转二叉树
    • (1)题目描述:
    • (2)思路表述:
    • (3)代码实现:
  • 六、另一颗树的子树
    • (1)题目描述:
    • (2)思路表述:
    • (3)代码实现:
  • 七、二叉树的构建及遍历
    • (1)题目描述:
    • (2)思路表述:
    • (3)代码实现:

一、单值二叉树

(1)题目描述:

点击链接
在这里插入图片描述

(2)思路表述:

  1. 如果传回来是空节点,那么就返回真。
  2. 如果传过来只有一个节点,那么我们也返回真
  3. 首先我们应该先判断不相等的,因为相等的他肯定要递归嘛(最值得注意的是你得先判断这个左/右子树,它存在不存在!只有左/右子树存在了,才能判断左/右子树中的值跟它的根节点是否相等。如果左子树不存在,我们都不需要判断它!如果左子树不存在,我们就直接访问空了,这样会报错的。)
  4. 如果以上的三种情况都不符合的话,我们就继续递归往下走。

(3)代码实现:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/
bool isUnivalTree(struct TreeNode* root) 
{//1.如果传回来是空节点,那么就返回真。if(root==NULL){return true;}//2.如果传过来只有一个节点,那么我们也返回真if(root->left==NULL&&root->right==NULL){return true;}//3.首先我们应该先判断不相等的,因为相等的他肯定要递归嘛//最值得注意的是,你得先判断这个左/右子树,它存在不存在!只有左/右子树存在了,才能判断左/右子树中的值跟它的根节点是否相等。如果左子树不存在,我们都不需要判断它!如果左子树不存在,我们就直接访问空了,这样会报错的。if(root->left&&root->left->val!=root->val){return false;}else if(root->right&&root->right->val!=root->val){return false;}//4.如果以上的三种情况都不符合的话,我们就继续递归往下走。return isUnivalTree(root->left)&&isUnivalTree(root->right);}

二、二叉树最大深度

(1)题目描述:

点击链接
在这里插入图片描述

(2)思路表述:

从根开始分别遍历左子树和右子树,取最大的就是整个树的最大深度

递归展开图理解
在这里插入图片描述

(3)代码实现:

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

三、检查两颗树是否相同

(1)题目描述:

点击链接
在这里插入图片描述

(2)思路表述:

1.如果两个二叉树都为空,则两个二叉树相同。
2.如果两个二叉树中有且只有一个为空,则两个二叉树一定不相同。

3.如果两个二叉树都不为空,那么首先判断它们的根节点的值是否相同,若不相同则两个二叉树一定不同,若相同,再分别判断两个二叉树的左子树是否相同以及右子树是否相同。这是一个递归的过程,因此可以使用深度优先搜索,递归地判断两个二叉树是否相同。

(3)代码实现:

/*** 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==NULL&&q==NULL){return true;}//一个为空,一个不为空if(p==NULL||q==NULL)//if((p==NULL&&q!=NULL)||(p!=NULL&&q==NULL)){return false;}//两个都不为空//1.先判断不相等if(p->val!=q->val){return false;}//2.如果相等return isSameTree(p->left,q->left)&&isSameTree(p->right,q->right);}

四、二叉树的前序遍历

(1)题目描述:

点击链接

在这里插入图片描述

(2)思路表述:

  1. 创建一个刚好满足所有储存树的结点的数组空间大小
  2. 以前序的方式把树中的结点依次放入数组中

(3)代码实现:

/*** 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().*/int TreeSize(struct TreeNode* root)
{return root==NULL?0:TreeSize(root->left)+TreeSize(root->right)+1;
}void Prevorder(struct TreeNode* root,int* arr,int* i)
{if(root==NULL){return;}arr[(*i)++]=root->val;Prevorder(root->left,arr,i);Prevorder(root->right,arr,i);
}int* preorderTraversal(struct TreeNode* root, int* returnSize) 
{//1.创建一个刚好满足所有储存树的结点的数组空间大小int n=TreeSize(root);int* arr=(int*)malloc(sizeof(int)*n);int i=0;//2.以前序的方式把树中的结点依次放入数组中Prevorder(root,arr,&i);*returnSize=n;return arr;
}

五、翻转二叉树

(1)题目描述:

点击链接
在这里插入图片描述

(2)思路表述:

  1. 我们从根节点开始,递归地对树进行遍历,并从叶子节点先开始翻转
  2. 一直遍历到树的的叶子节点
  3. 如果当前遍历到的节点 root 的左右两棵子树都已经翻转,那么我们只需要交换两棵子树的位置,即可完成以 root 为根节点的整棵子树的翻转。

不理解的时候:就画递归展开图就行

(3)代码实现:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*//*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*///不理解的时候:就画递归展开图就行!
struct TreeNode* invertTree(struct TreeNode* root) 
{if(root==NULL){return NULL;}//我们从根节点开始,递归地对树进行遍历,并从叶子节点先开始翻转struct TreeNode* left=invertTree(root->left);//一直遍历到树的的叶子节点struct TreeNode* right=invertTree(root->right);root->left=right;root->right=left;//如果当前遍历到的节点 root 的左右两棵子树都已经翻转,那么我们只需要交换两棵子树的位置,即可完成以 root 为根节点的整棵子树的翻转。return root;}

六、另一颗树的子树

(1)题目描述:

点击链接
在这里插入图片描述

(2)思路表述:

  1. 如果root为NULL,我们就返回空:NULL

  2. 首先我们先判断刚开始的root和subroot的根相不相等?如果相等,然后再判断是否是相同的树

  3. 如果刚开始root->val!=subroot->val,不要着急!继续遍历root的左,右子树

(3)代码实现:

/*** 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==NULL&&q==NULL){return true;}//一个为空,一个不为空if(p==NULL||q==NULL)//if((p==NULL&&q!=NULL)||(p!=NULL&&q==NULL)){return false;}//两个都不为空//1.先判断不相等if(p->val!=q->val){return false;}//2.如果相等return isSameTree(p->left,q->left)&&isSameTree(p->right,q->right);}bool isSubtree(struct TreeNode* root, struct TreeNode* subRoot)
{if(root==NULL){return false;}//2.首先我们先判断刚开始的root和subroot的根相不相等?如果相等,然后再判断是否是相同的树if(root->val==subRoot->val){if(isSameTree(root,subRoot)){return true;}//return isSameTree(root,subRoot);不能这样写,因为如果这样写的话,可能root的下面可能有子树和传过来的subroot是相同的树,//但是你没有判断,直接return返回了,这样就有所欠缺!}//3.如果刚开始root->val!=subroot->val,不要着急!继续遍历root的左,右子树return isSubtree(root->left,subRoot)||isSubtree(root->right,subRoot);}

七、二叉树的构建及遍历

(1)题目描述:

点击链接
在这里插入图片描述

(2)思路表述:

  1. 读入字符串
  2. 创建二叉树
  3. 中序打印二叉树

(3)代码实现:

#include <stdio.h>
#include <stdlib.h>
typedef struct TreeNode {char val;struct TreeNode* left;struct TreeNode* right;
}TreeNode;//MakeTree函数的意义在于将数组中的数据,以前序的方式创建一棵树
TreeNode* MakeTree(char* arr,int* n)
{if((arr[*n]=='#')||(arr[*n]=='\0')){return NULL;}//我要将数组中的数据放入树中的前提:是我要先创造一个树。TreeNode* newtree=(TreeNode*)malloc(sizeof(TreeNode));newtree->val=arr[(*n)++];//newtree->left=MakeTree(arr,(*n)++);newtree->left=MakeTree(arr,n);(*n)++;newtree->right=MakeTree(arr,n);return newtree;
}void InOrder(TreeNode* tree)
{if(tree==NULL){return ;}InOrder(tree->left);printf("%c ",tree->val);InOrder(tree->right);
}int main() {//int n = 0;//TreeSize(n);//int* arr = (int*)malloc(sizeof(int) * n);//scanf("%s", arr);char arr[101];scanf("%s",arr);int n=0;//创建一个n,作为一个我创建树的时候的一个标记指针,如果遇到空或者结尾的时候会返回TreeNode* tree=MakeTree(arr,&n);InOrder(tree);return 0;
}

好了,今天的分享就到这里了
如果对你有帮助,记得点赞👍+关注哦!
我的主页还有其他文章,欢迎学习指点。关注我,让我们一起学习,一起成长吧!
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

解套方式之认识T+0

在炒股中&#xff0c;大盘弱势调整中投资者如果被套&#xff0c;又不愿意止损离场&#xff0c;为了尽量减少亏损、摊低买入总成本尽可能早日解套&#xff0c;有一种操作对策——做“T0”摊低买入总成本&#xff0c;这种操作方式通过经常性的赚取短线利润&#xff0c;达到最终降…

docker容器中创建非root用户

简介 用 docker 也有一段时间了&#xff0c;一直在 docker 容器中使用 root 用户肆意操作。直到部署 stable diffusion webui 我才发现无法使用 root 用户运行它&#xff0c;于是才幡然醒悟&#xff1a;是时候搞个非 root 用户了。 我使用的 docker 镜像文件是 centos:centos…

LeetCode的几道题

一、捡石头 292 思路就是&#xff1a; 谁面对4块石头的时候&#xff0c;谁就输&#xff08;因为每次就是1-3块石头&#xff0c;如果剩下4块石头&#xff0c;你怎么拿&#xff0c;我都能把剩下的拿走&#xff0c;所以你就要想尽办法让对面面对4块石头的倍数&#xff0c; 比如有…

Linux shell中的函数定义、传参和调用

Linux shell中的函数定义、传参和调用&#xff1a; 函数定义语法&#xff1a; [ function ] functionName [()] { } 示例&#xff1a; #!/bin/bash# get limit if [ $# -eq 1 ] && [ $1 -gt 0 ]; thenlimit$1echo -e "\nINFO: input limit is $limit" e…

KM算法,C语言版本和Matlab版本

在这里我们不多介绍原理&#xff0c;直接看代码就好了。 C语言版本 #include<stdio.h> #include<string.h> const int maxn305; const int INF(1<<30)-1; int g[maxn][maxn]; int lx[maxn],ly[maxn]; int match[maxn]; bool visx[maxn],visy[maxn]; int sla…

C 标准库 <math.h>

C 标准库 <math.h> C <math.h>头文件声明了一组函数来执行数学运算&#xff0c;例如&#xff1a;sqrt()计算平方根&#xff0c;log()查找数字的自然对数&#xff0c;等等。 math.h 头文件定义了各种数学函数和一个宏。在这个库中所有可用的函数都带有一个 double…

CPU 使用率和负载Load

优质博文&#xff1a;IT-BLOG-CN 一、CPU 使用率 CPU使用率是 CPU处理非空闲任务所花费的时间百分比 。例如单核CPU 1s内非空闲态运行时间为0.8s&#xff0c;那么它的CPU使用率就是80%&#xff1b;双核CPU 1s内非空闲态运行时间分别为0.4s和0.6s&#xff0c;那么&#xff0c;…

IDEA2023安装教程(超详细)

文章目录 前言安装IntelliJ IDEA1. 下载IntelliJ IDEA2. 运行安装程序3. 选择安装路径4. 选择启动器设置5. 等待安装完成6. 启动IntelliJ IDEA7. 配置和设置8. 激活或选择许可证9. 开始使用 总结 前言 随着软件开发的不断发展&#xff0c;IntelliJ IDEA成为了许多开发人员首选…

数据结构 / 队列 / 循环队列 / 队列元素个数计算和遍历代码

1.队列元素个数计算和遍历代码 void output(queue *list) {if(NULLlist||list->frontlist->rear) //判断队列是否创建或空{puts("error or empty");return;}//循环结束判断条件是看是否到队尾//循环自增需要%MAXSIZEfor(int ilist->front; i!list->rear;…

基于JSP的网络考试系统/在线考试系统的设计与实现

摘 要 网络考试系统是由高校的一个网络考试&#xff0c;按照章程自主开展网络考试系统。网络考试是实施素质教育的重要途径和有效方式&#xff0c;在加强校园文化建设、提高学生综合素质、引导学生适应社会、促进学生成才就业等方面发挥着重要作用&#xff0c;是新形势下有效凝…

HNU-青蛙与蚊子

【问题描述】 有 n 只青蛙位于坐标轴 OX 上&#xff0c;对于每只青蛙&#xff0c;有两个已知值 xi、ti&#xff0c;表示第 i 只青蛙在坐标的位置&#xff08;各不相同&#xff09;以及它的舌头的长度。同样有 m 只蚊子一只接一只的落到坐标轴上&#xff0c;对于每只蚊子&#x…

RHCE学习笔记(RHEL8) - RH294

Chapter Ⅰ 介绍Ansible ansible ansible是一款开源自动化平台 ansible围绕一种无代理架构构建&#xff0c;在控制节点上安装ansible&#xff0c;且客户端不需要任何特殊的代理软件&#xff1b;ansible使用SSH等标准协议连接受管主机&#xff0c;并在受管主机上运行代码或命令来…

在cmd下查看mysql表的结构信息

我提前已经在mysql数据库中创建了一个表&#xff1a; 在cmd下&#xff0c;登录mysql以后&#xff0c;使用命令describe 表名、或者explain 表名可以查看表结构信息。但在实践中&#xff0c;查看表结构&#xff0c;多用describe命令&#xff0c;而查看执行计划用explain。 例…

p标签在div中居中

新建一个html文件&#xff0c;命名为test.html&#xff0c;用于讲解如何在css中让div中的p标签居中。 在test.html文件内&#xff0c;在div内&#xff0c;使用p标签创建一行文字&#xff0c;用于测试。 在test.html文件内&#xff0c;设置div标签的class属性为mydiv。 在…

2312skia,12画布包与路径包

画布包 Skia现在提供了,在Web上轻松部署图形API的WebAssembly构建,即CanvasKit. CanvasKit提供了测试新的Canvas和SVG平台API的地基,从而在Web平台上,实现快节奏开发.还可用作要求如Skia的Lottie动画支持等边角特征的自定义Web应用的部署机制. 特征 1,按允许直接绘画到HTML画…

MySQL - 多表查询

文章目录 1.聚合查询2.分组查找3.联合查询内连接外连接自连接子查询合并查询 SQL查询各关键字的执行先后顺序 总结 本文开始 1.聚合查询 聚合查询&#xff0c;使用的是聚合函数&#xff1a;count()&#xff0c;sum()&#xff0c;avg()&#xff0c;max()&#xff0c;min coun…

Hdoop学习笔记(HDP)-Part.05 Yum源配置

目录 Part.01 关于HDP Part.02 核心组件原理 Part.03 资源规划 Part.04 基础环境配置 Part.05 Yum源配置 Part.06 安装OracleJDK Part.07 安装MySQL Part.08 部署Ambari集群 Part.09 安装OpenLDAP Part.10 创建集群 Part.11 安装Kerberos Part.12 安装HDFS Part.13 安装Ranger …

mysql常用命令行代码

连接到 MySQL 服务器&#xff1a; mysql -u your_username -p替换 your_username 为你的 MySQL 用户名。系统会提示你输入密码。 退出 MySQL 命令行&#xff1a; EXIT;或者按 Ctrl D。 显示所有数据库&#xff1a; SHOW DATABASES;选择数据库&#xff1a; USE your_database…

计算机网络扫盲(1)——因特网

一、概述 因特网是一个世界范围的计算机网络&#xff0c;即它是一个互联了遍及全世界数十亿计算设备的网络。大家对此应该并不陌生&#xff0c;我们身边有着不计其数的计算机设备被接入了因特网&#xff0c;如今计算机网络这个术语似乎已经有点过时了&#xff0c;用因特网的术语…

CRM系统是怎样帮助销售流程自动化的?

销售业绩是衡量企业经营的重要指标&#xff0c;也是销售人员一直要达成的目标。销售业绩能否提高取决于销售人员的能力、客户服务水平&#xff0c;还需要借助有效的工具。CRM系统就是这样的一款软件。企业如何提高销售业绩&#xff1f;不妨试试CRM销售流程自动化。 CRM如何实现…