二叉树例题分享

文章目录

  • 二叉树例题分享
      • [235. 二叉搜索树的最近公共祖先](https://leetcode.cn/problems/lowest-common-ancestor-of-a-binary-search-tree/)
      • [701. 二叉搜索树中的插入操作](https://leetcode.cn/problems/insert-into-a-binary-search-tree/)
      • [108. 将有序数组转换为二叉搜索树](https://leetcode.cn/problems/convert-sorted-array-to-binary-search-tree/)
      • [450. 删除二叉搜索树中的节点](https://leetcode.cn/problems/delete-node-in-a-bst/)

二叉树例题分享

235. 二叉搜索树的最近公共祖先

题目

在这里插入图片描述

代码

struct TreeNode* lowestCommonAncestor(struct TreeNode* root, struct TreeNode* p,struct TreeNode* q) {struct TreeNode* ans = root;while (ans != NULL) {if (ans->val > p->val && ans->val > q->val) {ans = ans->left;} else if (ans->val < p->val && ans->val < q->val) {ans = ans->right;} else {return ans;}}return ans;
}

题解

本题要求我们找到二叉搜索树中两个节点的最小公共祖先,因为是二叉搜索树,所以实现起来还是比较简单的,因为二叉搜索树的左子树数值一定小于根节点数值小于右子树数值。

多以我们遍历一遍二叉树就可以找到答案:

  • 如果ans节点数值同时大于p,q数值,那么p,q一定在ans节点的左边,向左遍历;
  • 如果ans节点数值同时小于p,q数值,那么p,q一定在ans节点的右边,向右遍历;
  • 如果一大一小,那证明找到了最近公共祖先。

总体来说只要我们知道在什么情况下是最近公共祖先,我们就可以轻松实现本题要求。

701. 二叉搜索树中的插入操作

题目

在这里插入图片描述

代码

struct TreeNode* insertIntoBST(struct TreeNode* root, int val) {struct TreeNode* ans = root;struct TreeNode* new = (struct TreeNode*)malloc(sizeof(struct TreeNode));new->left = NULL;new->right = NULL;new->val = val;if (root == NULL)return new;while (root) {if (root->val > val) {if (root->left != NULL)root = root->left;else {root->left = new;return ans;}} else {if (root->right != NULL)root = root->right;else {root->right = new;return ans;}}}return ans;
}

题解

本题可以使用两种方法去实现:

第一种

​ 迭代法

迭代法是我在没有看题解情况下完成的。

因为是二叉搜索树,所以我们遍历一次便可以实现。

我们在遍历二叉树的时候,如果本节点的数值大于val,则证明val应该插入到左子树中,反之插入右子树中,我们只需要继续判断本节点的左孩子节点(右孩子节点)是否为空,如果不为空则继续遍历,如果为空则证明该位置就为插入位置。

下面是代码:

struct TreeNode* insertIntoBST(struct TreeNode* root, int val) {if (root == NULL)return root;struct TreeNode* ans = root;struct TreeNode* new = (struct TreeNode*)malloc(sizeof(struct TreeNode));new->left = NULL;new->right = NULL;new->val = val;while (root) {if (root->val > val) {if (root->left != NULL)root = root->left;else {root->left = new;return ans;}} else {if (root->right != NULL)root = root->right;else {root->right = new;return ans;}}}return ans;
}

第二种

​ 递归法

  • 终止递归是如果遇到了空节点,则证明该位置就应该是插入位置,直接返回新节点接可以了;
  • 后面我们考虑一层递归的逻辑,我们判断val与root->val的大小关系,然后继续遍历左孩子节点或右孩子节点(之后会返回),并且用root->left或root->right接住返回值;
  • 最后返回root就可以了。

最后的代码是这样的:

struct TreeNode* insertIntoBST(struct TreeNode* root, int val) {if (root == NULL) {struct TreeNode* new =(struct TreeNode*)malloc(sizeof(struct TreeNode));new->left = NULL;new->right = NULL;new->val = val;return new;}if (val > root->val)root->right = insertIntoBST(root->right, val);if (val < root->val)root->left = insertIntoBST(root->left, val);return root;
}

108. 将有序数组转换为二叉搜索树

题目

在这里插入图片描述

代码

struct TreeNode* Traval(int* nums, int left, int right) {if (left > right)return NULL;int mid = (left + right) / 2;struct TreeNode* root = (struct TreeNode*)malloc(sizeof(struct TreeNode));root->val = nums[mid];root->left = Traval(nums, left, mid - 1);root->right = Traval(nums, mid + 1, right);return root;
}struct TreeNode* sortedArrayToBST(int* nums, int numsSize) {return Traval(nums, 0, numsSize - 1);
}

题解

本题要求我们将给定的升序数组转换成一棵平衡二叉搜索树。

我们的思路就是每次都将数组中的中间元素设置成根节点,然后将左边的设置为左子树,右边的设置为右子树,然后对左子树和右子树再进行相同的处理(运用递归)。

下面是代码:

struct TreeNode* Traval(int* nums, int left, int right) {if (left > right)return NULL;int mid = (left + right) / 2;struct TreeNode* root = (struct TreeNode*)malloc(sizeof(struct TreeNode));root->val = nums[mid];root->left = Traval(nums, left, mid - 1);root->right = Traval(nums, mid + 1, right);return root;
}struct TreeNode* sortedArrayToBST(int* nums, int numsSize) {return Traval(nums, 0, numsSize - 1);
}

这里要说的是上面的终止条件(left>right),这里是因为我们传参是left和mid-1或者mid+1和right,如果left>right就证明节点为空,直接返回空节点就可以了。

450. 删除二叉搜索树中的节点

题目
在这里插入图片描述

代码

struct TreeNode* deleteNode(struct TreeNode* root, int key){if(root==NULL)return NULL;if(root->val==key){if(root->left==NULL&&root->right==NULL)return NULL;else if(root->left==NULL&&root->right!=NULL)return root->right;else if(root->left!=NULL&&root->right==NULL)return root->left;else if(root->left!=NULL&&root->right!=NULL){struct TreeNode* cur=root->right;while(cur->left!=NULL)cur=cur->left;cur->left=root->left;return root->right;}}if(root->val>key)root->left=deleteNode(root->left,key);if(root->val<key)root->right=deleteNode(root->right,key);return root;
}

题解

本题我们在删除的地方有五种情况:

  • 第一种情况:没找到删除的节点,遍历到空节点直接返回了
  • 找到删除的节点
    • 第二种情况:左右孩子都为空(叶子节点),直接删除节点, 返回NULL为根节点
    • 第三种情况:删除节点的左孩子为空,右孩子不为空,删除节点,右孩子补位,返回右孩子为根节点
    • 第四种情况:删除节点的右孩子为空,左孩子不为空,删除节点,左孩子补位,返回左孩子为根节点
    • 第五种情况:左右孩子节点都不为空,则将删除节点的左子树头结点(左孩子)放到删除节点的右子树的最左面节点的左孩子上,返回删除节点右孩子为新的根节点。

如果我们搞清楚了这五种情况,我们运用递归很容易就可以实现这道题。

已经到底啦!!

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

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

相关文章

Go微服务: go-micro集成consul的注册中心和配置中心

微服务与注册中心的关系图 这个图很好说明了微服务之间的关系&#xff0c;以及consul注册中心的重要性 环境准备 1 &#xff09;consul 集群 假设consul 集群已经搭建&#xff0c;已有5台server和2台client这里2台client被nginx做负载均衡&#xff0c;假设最终本地的访问地址…

五、Jenkins、Docker、SpringClound持续集成

Jenkins、Docker、SpringClound持续集成 一、部署介绍1.部署图2.微服务项目结构3.项目启动顺序 二、微服务项目在Windows运行1.配置java、maven环境2.初始化数据库表/数据2.1 tensquare_gathering服务表2.2 tensquare_gathering服务表 3.启动微服务4.微服务接口测试4.1 获取用户…

回归预测 | Matlab基于RIME-SVR霜冰算法优化支持向量机的数据多输入单输出回归预测

回归预测 | Matlab基于RIME-SVR霜冰算法优化支持向量机的数据多输入单输出回归预测 目录 回归预测 | Matlab基于RIME-SVR霜冰算法优化支持向量机的数据多输入单输出回归预测预测效果基本描述程序设计参考资料 预测效果 基本描述 1.Matlab基于RIME-SVR霜冰算法优化支持向量机的数…

Qt 窗⼝

Qt 窗⼝ 菜单栏创建菜单栏在菜单栏中添加菜单创建菜单项在菜单项之间添加分割线综合⽰例 ⼯具栏创建⼯具栏设置停靠位置设置浮动属性设置移动属性综合⽰例状态栏状态栏的创建在状态栏中显⽰实时消息在状态栏中显⽰永久消息 浮动窗⼝浮动窗⼝的创建设置停靠的位置 对话框对话框介…

数据结构与算法——20.B-树

这篇文章我们来讲解一下数据结构中非常重要的B-树。 目录 1.B树的相关介绍 1.1、B树的介绍 1.2、B树的特点 2.B树的节点类 3.小结 1.B树的相关介绍 1.1、B树的介绍 在介绍B树之前&#xff0c;我们回顾一下我们学的树。 首先是二叉树&#xff0c;这个不用多说&#xff…

Unity类银河恶魔城学习记录12-14 p136 Merge Skill Tree with Sword skill源代码

Alex教程每一P的教程原代码加上我自己的理解初步理解写的注释&#xff0c;可供学习Alex教程的人参考 此代码仅为较上一P有所改变的代码 【Unity教程】从0编程制作类银河恶魔城游戏_哔哩哔哩_bilibili CharacterStats.cs using System.Collections; using System.Collections.…

【linux深入剖析】深入理解软硬链接 | 动静态库的制作以及使用

&#x1f341;你好&#xff0c;我是 RO-BERRY &#x1f4d7; 致力于C、C、数据结构、TCP/IP、数据库等等一系列知识 &#x1f384;感谢你的陪伴与支持 &#xff0c;故事既有了开头&#xff0c;就要画上一个完美的句号&#xff0c;让我们一起加油 目录 1.理解软硬链接1.1 操作观…

基于机器学习的人脸发型推荐算法研究与应用实现

1.摘要 本文主要研究内容是开发一种发型推荐系统&#xff0c;旨在识别用户的面部形状&#xff0c;并根据此形状推荐最适合的发型。首先&#xff0c;收集具有各种面部形状的用户照片&#xff0c;并标记它们的脸型&#xff0c;如长形、圆形、椭圆形、心形或方形。接着构建一个面部…

ASP.NET公交车管理系统的实现与设计

摘 要 随着经济的日益增长&#xff0c;信息化时代已经到来&#xff0c;生活中各种信息趋向数字化、清晰化。公交车作为现代城市生活中一种重要的交通工具&#xff0c;其数量增多&#xff0c;车型也不再单一&#xff0c;雇用的司机增多&#xff0c;这样使得公交车公司的车辆信…

HTML重要标签重点及属性(表格表单列表)——之转生在异世界学前端

表格标签 table是用于定义表格的标签 tr是用于定义表格的行 td是用来定义表格的列&#xff0c;th是表头一般只有一个表头会加粗 表格属性border是设置边框值为1;1是有边框&#xff0c; align设置居中对齐方式center&#xff0c;left&#xff0c;right cellpadding设置文字…

ELFK日志分析系统之搭建ELF+Filebeaat+Zookeeper+Kafka

引言 结合前面所学 http://ELK日志分析系统 一、为什么要做日志分析平台 随着业务量的增长&#xff0c;每天业务服务器将会产生上亿条的日志&#xff0c;单个日志文件达几个GB&#xff0c;这时我们发现用Linux自带工具&#xff0c;cat grep awk 分析越来越力不从心了&#…

pixhawk控制板的ArduPilot固件编译

0. 环境 - ubuntu18&#xff08;依赖python2和pip&#xff0c;建议直接ubuntu18不用最新的&#xff09; - pixhawk 2.4.8 - pixhawk 4 1. 获取源码 # 安装git sudo apt install git # 获取源码 cd ~/work git clone --recurse-submodules https://github.com/ArduPilot/a…