【零基础算法】C语言实现二叉搜索树

news2025/1/8 6:03:02

目录

一,定义

二,性质

三,基本操作

1,初始化

2,查找

3,插入(建树) 

4.删除结点

四,总结 


 

一,定义

二叉查找树(Binary Search Tree),(又:二叉搜索树,二叉排序树)它或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值; 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值; 它的左、右子树也分别为二叉排序树。二叉搜索树作为一种经典的数据结构,它既有链表的快速插入与删除操作的特点,又有数组快速查找的优势;所以应用十分广泛,例如在文件系统和数据库系统一般会采用这种数据结构进行高效率的排序与检索操作。

二,性质

二叉搜索树的最主要的性质如下:

        1,若它的左子树不空,则左子树上所有的节点的值均小于它的根节点的值

        2,若它的右子树不空,则右子树上所有的节点的值均大于它的根节点的值

        3,二叉搜索树的左,右子树也分别为二叉搜索树

三,基本操作

实际操作过程中,常常需要先进行预处理的一些定义,以便我们之后写代码更加明了。

typedef int TreeElement;
/*
#define less(A,B) (A<B)
#define eq(A,B) (!less(A,B) && !less(B,A))
#define swap(A,B) {TreeElement t = A;A=B;B=t;}
*/
typedef struct BINode{
	TreeElement val;
	struct BINode* lchild, *rchild;
}BiNode, *BiTree;

BiTree BuyNode(TreeElement val) {
	BiTree tmp = (BiTree)malloc(sizeof(BiNode));
	tmp->val = val;
	tmp->lchild = NULL;
	tmp->rchild = NULL;
	return tmp;
}

对结构体以及结构体的指针进行typedef,便于之后的书写。(为了理解的方便,以及这里就尽量少使用自己define的结构)

1,初始化

对于树的初始化,很显然是返回一棵空树的指针。

BiTree IniTree() {
	BiTree T = (BiTree)malloc(sizeof(BiNode));
	return T;
}

2,查找

令要查找的数为key值。由于二叉搜索树的性质,所以,查找的步骤即为: 

    1,若key值小于结点值,那么继续寻找其左子树

    2,若key值大于结点值,那么继续寻找其右子树

    3,若key值等于结点值,那么找到该数,返回该位置节点

    4,若一直查找到叶子结点,还未查找到该数,则找不到,返回空指针

//非递归
BiTree BSSearch(TreeElement x, BiTree root) {
	BiTree p = root;   //令p=树的根

	while (p) {
		if (x < p->val)  p = p->lchild;
		else if (x > p->val) p = p->rchild;
		else  break;
	}

	return p;
}

//递归
BiTree BSSearch(TreeElement x, BiTree root) {
	if (!root)   return NULL;
	if (root->val = x)  return root;
	if (x < root->val)  return BSSearch(x, root->lchild);
	if (x> root->val)  return BSSearch(x, root->rchild);
}

3,插入(建树) 

创建树的过程,实际上就是不断插入数据的过程,也就是进行二叉搜索树的插入。

插入遵循若已有相同元素,则无需再进行插入的原则。

BiTree BSInsert(TreeElement x, BiTree root) {
	BiTree pp,p,newnode;
	pp = p = root;
	
	while (p) {//p为搜索指针
		pp = p;//指向p的双亲结点
		if (x < p->val) p = p->lchild;
		else if (x>p->val) p = p->rchild;
		else return NULL;
	}
    //找到要插入的结点,即进行搜索的过程
	newnode = BuyNode(x);

	if (root) {
		if (x < pp->val)  pp->lchild = newnode;
		else if (x>pp->val) pp->lchild = newnode;
	}//如果树非空,就对pp操作,比pp指向值小,链接为左子树,否则为右子树
	else {
		root = newnode;//为空则让树为根节点
	}

	return newnode;
}

4.删除结点

删除结点比较麻烦,首先要找到存储x的结点。

1,若这只是一个叶结点,则只删除叶结点就行。

2,若只有左子树或者只有右子树,那么删除对应结点,使其左子树/右子树代替其位置即可

3,若既有左子树又有右子树,则需找到一个替代结点,可以是其前驱结点,也可以是后继结点。然后交换两者的值,删除替代结点即可。

     (找前驱:从当前结点左转,之后右转到尽头

         找后继:从当前结点右转,之后左转到尽头)

 

bool BSDelete(BiTree root,TreeElement x) {
	BiTree p,pp; //搜索指针找到要删除的结点
	pp = p = root;
	while (p) {
		pp = p;
		if (x < p->val)  p = p->lchild;
		else if (x>p->val) p = p->rchild;
		else break;
	}
	if (!p)  return false;//找不到就不用删除

	if (p->lchild && p->rchild){
		//这里使用找前驱结点,左子树后一直找右子树
		BiTree tmp, ptmp;
		ptmp = p;
		tmp = p->lchild;
		while (tmp->rchild) {
			ptmp = tmp;
			tmp = tmp->rchild;
		}
		p->val = tmp->val;
		pp = ptmp;
		p = tmp;
	}
	//此时最多只有一个子树即左子树或右子树
	BiTree tmp;
	if (p->lchild) tmp = p->lchild;
	else  tmp = p->rchild;

	if (p == root) {
		root = tmp;
	}
	else {
		if (pp->lchild == p) {
			pp->lchild = tmp;
		}
		else{
			pp->rchild = tmp;
		}
	}

	free(p);
	return true;
}

四,总结 

本次也是很久没有更新文章了,趁着1024节日回来更新,希望各位能多点赞收藏支持一下,之后会重新开始坚持出c语言算法的实现的,各位的关注就是我写文章最大的动力,那么我们下次文章再见

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

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

相关文章

记一次网络安全渗透测试实战指南

1.信息收集 网址已无法访问&#xff0c;就不贴了 可以使用Fofa&#xff0c;火线&#xff0c;zoomeye&#xff0c;searchcode.com等爬取相关的资产&#xff0c;重点关注一些有漏洞暴露的框架和服务例如&#xff1a;泛微&#xff0c;PHP&#xff0c;Tomca&#xff0c;后台&#x…

71.(后端)角色接口携带权限数据——flask两张表之间多对多关系的使用与层级关系的输出

1.ORM关系之多对多 1.1 什么时候使用多对多关系 例如&#xff0c;我们我们的项目中&#xff0c;一个用户可以拥有多个角色&#xff0c;同样的&#xff0c;一个角色可以给多个用户。通俗来说&#xff0c;一个用户可以购买多个商品&#xff0c;多个商品可以被一个用户购买 1.2…

【FPGA】Verilog编程实现SDRAM读写(一) ----- 初始SDRAM

文章目录一. 存储器及SDRAM分类1. 存储器分类2. 半导体存储器分类3. SDRAM分类二. 什么是SDRAM&#xff1f;1. SDRAM基本概念2. SDRAM存储阵列3. SDRAM基本存储单元4. BANK概念5. SDRAM容量计算6. SDRAM功能框图7. SDRAM信号引脚8. SDRAM操作命令8.1 禁止命令&#xff08; INHI…

mysql做查询时,第一次很慢,第二三次就会很快?

前言 sql语句第一次查询慢的原因不仅仅是因为执行计划没有被缓存这么简单,有时候你会发现sql语句重用了执行计划,但是第一次查询时还是很慢. 最主要的原因是第一次查询的时候,mysql会将查询出的部分数据和索引从磁盘加载到内存作为缓存,而第二三此查询的时候就直接从内存缓存…

Spring - 手把手分析 IoC 容器创建过程

概述 这里我们以 Spring 5.2.8.RELEASE 版本为例&#xff0c;看一下 IoC 容器 的创建过程。同时我们使用 java-based 的方式实例化 IoC 容器&#xff0c;即使用 AnnotationConfigApplicationContext Configuration 的方式配置容器需要的组件。 ApplicationContext ctx new …

【云IDE初体验】与君相逢恨晚,真正的轻量级开发工具

云IDE产品介绍 云IDE使用教程 免费使用地址&#xff1a;点击【云IDE】&#xff0c;即可开始创建工作空间啦~ 云IDE1.云IDE介绍2. 使用流程3. 体验总结作为一名大学生&#xff0c;学习的地点很关键&#xff0c;尤其是我们计算机系&#xff0c;更是离不开电脑&#xff0c;去图书馆…

调度线程池 ScheduledThreadPoolExecutor 的正确使用姿势

前言 项目中经常会遇到一些非分布式的调度任务&#xff0c;需要在未来的某个时刻周期性执行。实现这样的功能&#xff0c;我们有多种方式可以选择&#xff1a; Timer类&#xff0c; jdk1.3 引入&#xff0c;不推荐 它所有任务都是串行执行的&#xff0c;同一时间只能有一个任…

【C语言】移位操作符 位操作符 - 对二进制位进行精准操作【+面试题目】_[初阶篇]

快速导航 【前言】 1.移位操作符 1.1左移操作符(<<) 1.2右移操作符(>>) 2.位操作符 2.1 & 按位与 2.2 | (按位或) 2.3 ^ (按位异或) 3.面试题目 3.1 交换两个变量&#xff08;不创建临时变量&#xff09; 3.2统计二进制中1的个数 3.2.1 方法一&#xff1a;…

复合事件归因分析

1 复合事件 1.1 概述 1.2 类型 1.2.1 先决条件事件&#xff08;preconditioned events&#xff09; 1.2.2 多变量事件&#xff08;multivariate CEs&#xff09; eg.高温干旱 1.2.3 时间复合事件&#xff08;temporally CEs&#xff09; eg.旱涝急转 1.2.4 空间复合事件…

电子电路设计基本概念100问(二)【学习目标:原理图、PCB、阻抗设计、电子设计基本原则、基本原器件等】

笔者电子信息专业硕士毕业&#xff0c;获得过多次电子设计大赛、大学生智能车、数学建模国奖&#xff0c;现就职于南京某半导体芯片公司&#xff0c;从事硬件研发&#xff0c;电路设计研究。对于学电子的小伙伴&#xff0c;深知入门的不易&#xff0c;特开次博客交流分享经验&a…

【每天学习一点新知识】网络安全--拒绝服务攻击

目录 1、SYN泛洪攻击 SYN泛洪攻击原理 攻击过程 防御机制 2、Smurf攻击 Smurf攻击原理 间接攻击 放大攻击 防御机制 3、DDoS DDoS原理 直接DDoS攻击 间接DDoS攻击 防御机制 1、SYN泛洪攻击 SYN泛洪攻击原理 终端访问Web服务器之前需要和服务器之间建立TCP连接。W…

万字长文解析Scaled YOLOv4模型(YOLO变体模型)

一&#xff0c;Scaled YOLOv4 摘要1&#xff0c;介绍2&#xff0c;相关工作 2.1&#xff0c;模型缩放 3&#xff0c;模型缩放原则 3.1&#xff0c;模型缩放的常规原则3.2&#xff0c;为低端设备缩放的tiny模型3.3&#xff0c;为高端设备缩放的Large模型 4&#xff0c;Scaled-YO…

大学毕业后,我就送了2个月外卖,哭了一整晚

先简单介绍一下自己&#xff0c;我来自湛江&#xff0c;大学学的的物流管理专业&#xff0c;现在就职于一家互联网公司&#xff0c;从事软件测试工作。 我来自湛江的一个偏远农村&#xff0c;家里兄弟姐妹多&#xff0c;父母无力负担我的学费&#xff0c;很多时候学费都是靠姐…

红黑树 - c++

文章目录&#xff1a;红黑树的介绍红黑树节点定义红黑树的插入操作红黑树的删除红黑树的验证红黑树 vs AVL树红黑树的介绍 红黑树(Red-Black-Tree)&#xff0c;通常写为 R-B Tree。它是一种特殊的二叉搜索树。红黑树的每个节点上都有一个存储位来标识节点的颜色&#xff0c;可…

积木报表—JimuReport v1.5.4版本发布,免费的可视化Web报表工具

项目介绍 一款免费的低代码可视化报表&#xff0c;像搭建积木一样在线拖拽设计&#xff01;低代码开发必备&#xff0c;功能涵盖&#xff0c;数据报表、打印设计、图表报表、大屏设计等&#xff01; 秉承“简单、易用、专业”的产品理念&#xff0c;极大的降低报表开发难度、缩…

【css伪类选择器及透明度——附项目图片及代码】

不知不觉&#xff0c;又鸽了好长时间了&#xff0c;非常抱歉&#xff0c;没办法&#xff0c;毕竟开学了&#xff0c;今天课少&#xff0c;抽出了两个小时写了一篇css的&#xff0c;每天不是被催更&#xff0c;就是在催更的路上。放心&#xff0c;小陈陈有时间一定会给大家分享好…

SVM 支持向量机

SVM 支持向量机SVM 原理最优化问题线性不可分sklearn 调用 SVM核函数SVM 原理 前置知识&#xff1a;用迭代策略来划分样本&#xff0c;请猛击《神经元的计算》。 SVM 也是用一条迭代的直线来划分不同数据之间的边界&#xff1a; .- 是一条直线&#xff08;线性函数&#xff09…

数据结构c语言版第二版(严蔚敏)第五章笔记

目录 树和二叉树的定义 树的定义 树的基本术语 二叉树的定义 二叉树的性质和存储结构 二叉树的性质 二叉树的存储结构 顺序存储结构 链式存储结构 遍历二叉树和线索二叉树 遍历二叉树 先序遍历 中序遍历 后序遍历 前序遍历的递归算法 中序遍历的递归算法 后序…

SARScape中用sentinel-1数据做SBAS-InSAR完整流程(2/2)

书接上回&#xff1a;SARScape中用sentinel-1数据做SBAS-InSAR完整流程&#xff08;1/2&#xff09; SARScape中用sentinel-1数据做SBAS-InSAR完整流程&#xff08;2/2&#xff09;7 反演第一步Inversion&#xff1a;First Step7.1 导入设置7.2 optional file7.3 parameters参数…

齐博x1用户登录接口

用户的登录主要涉及到小程序登录、APP的帐号密码登录、APP的微信开发平台帐号登录。 相应的地址是&#xff1a;http://qb.net/index.php/index/wxapp.login/index.html 涉及到的方法如下 上面的地址&#xff0c;默认是小程序的登录与注册。 http://qb.net/index.php/index/wxa…