二叉排序树--c++

【相关知识】

二叉排序树(也称二叉查找树):或者是一棵空的二叉树,或者是具有下列性质的二叉树:

⑴ 若它的左子树不空,则左子树上所有结点的值均小于根结点的值;

⑵ 若它的右子树不空,则右子树上所有结点的值均大于根结点的值;

⑶ 它的左右子树也都是二叉排序树。

【题目描述】

①给定输入序列,按照二叉排序树算法创建二叉排序树。输出二叉排序树的中序遍历。

②输入一个待查找的整数x,如果整数x在二叉排序树中存在,这输出"Found.",否则输出"Not found."要求按照前序遍历顺序进行递归查找,要输出查找的过程。

③输入一个待查找的整数x,如果整数x在二叉排序树中存在,则输出"Found.",并删除找到的结点,并且输出删除后的二叉排序树的中序遍历序列。如果整数x不存在,否则输出"Not found."。

④然后按后序遍历销毁这棵树。

【测试数据】

【数据1】

请输入二叉树结点个数:

11

请输入结点数据:

38 12 34 56 13 6 98 3 17 40 78

请输入待查找的整数:

40

Searching...

38 56 40

Found.

请输入待删除的结点:

40

Found.

PreOrder sequence after deleted: 38 12 6 3 34 13 17 56 98 78

InOrder sequence after deleted: 3 6 12 13 17 34 38 56 78 98

Destroy tree...

Delete:3
Delete:6
Delete:17
Delete:13
Delete:34
Delete:12
Delete:78
Delete:98
Delete:56
Delete:38

【数据2】

请输入二叉树结点个数:

11

请输入结点数据:

38 12 34 56 13 6 98 3 17 40 78

请输入待查找的整数:

14

Searching...

38 12 34 13 17

Not found.

请输入待删除的结点:

9

Not found.

Destroy tree...

Delete:3
Delete:6
Delete:17
Delete:13
Delete:34
Delete:12
Delete:40
Delete:78
Delete:98
Delete:56
Delete:38

【代码】

#include <iostream>
#include <algorithm>
#include <limits.h>
#include<string>
using namespace std;
const int MAX = 100;
struct BiNode
{
	int data;
	BiNode* lchild, * rchild;//左右儿子指针
};
BiNode* root = NULL;
static bool flag = false;
void inOrder(BiNode* bt)
{
	if (bt == NULL)
		return;
	else
	{
		inOrder(bt->lchild);
		cout << bt->data << " ";
		inOrder(bt->rchild);
	}
}
void preOrder(BiNode* bt)
{
	if (bt == NULL)
		return;
	else
	{
		cout << bt->data << " ";
		preOrder(bt->lchild);
		preOrder(bt->rchild);
	}
}
void release(BiNode* bt)
{
	if (bt != NULL)
	{
		release(bt->lchild);
		release(bt->rchild);
		delete bt;
		bt = NULL;
	}
}
void postOrder(BiNode* bt)
{
	if (bt != NULL)
	{
		postOrder(bt->lchild);
		postOrder(bt->rchild);
		cout << "Delete:" << bt->data << endl;
	}
}
void Insert(BiNode*& bt, int num)
{
	if (bt == NULL)
	{
		bt = new BiNode;
		bt->data = num;
		bt->lchild = NULL;
		bt->rchild = NULL;
	}
	else
	{
		if (num < bt->data)
			Insert(bt->lchild, num);
		else if (num > bt->data)
			Insert(bt->rchild, num);
	}
}
bool Search(BiNode* bt, int key)
{

	if (bt == NULL)
		return false;
	else
	{
		if (key < bt->data)
		{
			cout << bt->data << " ";
			Search(bt->lchild, key);
		}
		else if (key > bt->data)
		{
			cout << bt->data << " ";
			Search(bt->rchild, key);
		}
		else
		{
			cout << bt->data << " ";
			flag = true;
		}
		return flag;
	}
}
//删除结点
void deleteNode(BiNode*& bt)
{
	BiNode* p;
	if (bt->lchild == NULL && bt->rchild == NULL) //叶子结点
	{                                             //直接删除,再把该位置设为空
		p = bt;
		bt = NULL;
		delete p;
	}
	else if (bt->rchild == NULL) //右子树为空,只有左子树
	{
		p = bt;
		bt = bt->lchild;  //把删除结点的左子树拼接到删除节点的父节点的右边,作为父节点的右子树
		delete p;
	}
	else if (bt->lchild == NULL) //左子树为空,只有右子树,同上
	{
		p = bt;
		bt = bt->rchild;
		delete p;
	}
	else  //左右子树都不为空|将要删除结点的左子树中最大的结点替换该删除的结点
	{
		BiNode* parent, * pre;
		parent = bt;
		pre = bt->lchild;
		//转左,然后向右到尽头
		while (pre->rchild)
		{
			parent = pre;
			pre = pre->rchild;

		}
		bt->data = pre->data; //将根节点的左子树中的最大的节点赋给根节点,原本的根节点被替代
		if (parent != bt)
			parent->rchild = pre->lchild;  //pre的lchild与parent建立联系,pre被删掉
		else
			parent->lchild = pre->lchild;  //原来pre指向的结点,也就是最大的结点被删掉
		delete pre;
	}
}

//根据指定的关键数据找到要删除的节点的位置
bool deleteBST(BiNode*& bt, int key)
{
	if (bt == NULL)
	{
		return false;
	}
	else
	{
		if (bt->data == key) //找到关键词
			deleteNode(bt);  //删除
		else if (key < bt->data)  //如果关键词比当前结点数据小,继续在其左子树中查找
			return deleteBST(bt->lchild, key);
		else  //如果关键词比当前结点数据大,在其右子树中查找
			return deleteBST(bt->rchild, key);
		return true;  //查找成功
	}
}

int main()
{
	int n, key;
	int array[MAX] = { 0 };
	cout << "请输入二叉树结点个数:\n";
	cin >> n;
	cout << "请输入结点数据:\n";
	for (int i = 0; i < n; i++)
	{
		cin >> array[i];
	}
	for (int i = 0; i < n; i++)
	{
		Insert(root, array[i]);
	}
	//开始查找
	cout << "请输入待查找的整数:\n";
	cin >> key;
	cout << "Searching..." << endl;
	if (Search(root, key))
		cout << "\nFound." << endl;
	else
		cout << "\nNot found." << endl;

	cout << "请输入待删除的结点:\n";
	cin >> key;
	//开始删除
	if (deleteBST(root, key))
	{
		cout << "Found." << endl;
		cout << "PreOrder sequence after deleted: ";
		preOrder(root);
		cout << "\nInOrder sequence after deleted: ";
		inOrder(root);
	}
	else
		cout << "Not found." << endl;
	//销毁二叉树
	cout << endl << "Destroy tree..." << endl;
	postOrder(root);
	release(root);
	return 0;
}

【运行效果】

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

vivado HW_BITSTREAM、HW_CFGMEM

HW_比特流 描述 从比特流文件创建的硬件比特流对象hw_bitstream&#xff0c;用于关联 在Vivado的硬件管理器功能中使用硬件设备对象hw_device 设计套件。 比特流文件是从具有write_bitstream的放置和路由设计创建的 命令硬件位流对象是使用 create_hw_bitstream命令&#xff0c…

【Vue】vuex 的使用 - 创建仓库

通用的地方我们一般会称之为仓库 1.安装 vuex 安装vuex与vue-router类似&#xff0c;vuex是一个独立存在的插件&#xff0c;如果脚手架初始化没有选 vuex&#xff0c;就需要额外安装。 yarn add vuex3 或者 npm i vuex32.新建 store/index.js 专门存放 vuex ​ 为了维护项目…

vue2中如何使用函数式组件

vue2 中如何使用函数式组件 用 render 定义函数式组件如何处理 props如何在函数式组件中触发自定义事件&#xff1f;injection如何使用 computed 和 methods定义一个函数式组件的 MyButton函数式组件有何优势哪种场景适合使用函数式组件函数式组件的问题参考 函数式组件&#x…

MySQL-相关日志

官方文档 1、MySQL支持的日志 MySQL有不同类型日志文件&#xff0c;用来存储不同类型的日志&#xff0c;分别为 二进制日志、错误日志、通用查询日志、慢查询日志、中继日志、数据定义语句日志 慢查询日志&#xff1a;记录所有执行时间超过 long_query_time的所有查询&#xf…

【 技术栈】技术方案到底怎么写?

文章目录 一、背景二、技术方案重要性三、常见的技术方案有哪些内容1、系统用例2、功能整体链路2.1、核心业务流程 3、数据库设计4、接口设计5、非功能设计5.1、性能与稳定性5.2、监控 7、系统风险点评估 四、总结 一、背景 工作中&#xff0c;有一些需求或者技术改造&#xf…

前端开发高频面试题

好的&#xff0c;以下是对您提出的问题的详细回答&#xff1a; 说说vue动态权限绑定渲染列表&#xff08;权限列表渲染&#xff09; Vue中动态权限绑定渲染列表通常涉及以下步骤&#xff1a; 首先&#xff0c;通过API请求从服务器获取当前用户的权限数据。在Vue组件中&#xff…

uc/OS移植到stm32实现三个任务

文章目录 一、使用CubeMX创建工程二、uc/OS移植三、添加代码四、修改代码五、实践结果六、参考文章七、总结 实践内容 学习嵌入式实时操作系统&#xff08;RTOS&#xff09;,以uc/OS为例&#xff0c;将其移植到stm32F103上&#xff0c;构建至少3个任务&#xff08;task&#xf…

[pixi.js] 入门简单案例 简易时钟

老实说pixi虽然之前拿来做个几个简单的游戏&#xff0c;但是是好久前的了&#xff0c;又忘了&#xff0c;现在算是重新入门。 官网版本已经更新到v8去了&#xff0c;而react相关的pixi库pixi-react 虽然支持react18 但还是v6-v7的版本&#xff0c;既然已经看了v8的文档&#xf…

Web 版 | 开源数据库设计软件 | drawdb

文章目录 简介快速运行方式 1:本地运行方式 2:Docker 构建并运行方式 3:Docker 运行参考🚀 目标: 安装一个 Web 版本的 ER 图设计软件! 👉 GitHub: https://github.com/drawdb-io/drawdb 【11.7k ⭐】 简介 DrawDB:Free, simple, and intuitive database design …

【iOS】UI——关于UIAlertController类(警告对话框)

目录 前言关于UIAlertController具体操作及代码实现总结 前言 在UI的警告对话框的学习中&#xff0c;我们发现UIAlertView在iOS 9中已经被废弃&#xff0c;我们找到UIAlertController来代替UIAlertView实现弹出框的功能&#xff0c;从而有了这篇关于UIAlertController的学习笔记…

Idea解决堆栈溢出

废话不说了&#xff0c;这问题搞了我两天&#xff0c;最近在用内网办公&#xff0c;没用公网&#xff0c;所以博客暂时没更新

堆排序-调整算法

个人主页点这里!~ 1.堆 了解堆排序首先要了解一下堆这个数据结构 堆&#xff08;Heap&#xff09;是一种特殊的树形数据结构&#xff0c;它通常被表示为一个完全二叉树或近似完全二叉树&#xff0c;并且满足堆性质&#xff08;Heap Property&#xff09;。堆主要分为两种&…

wordpress主题导航主题v4.16.2哈哈版

1.下载授权接口源码onenav-auth-api-v2.zip &#xff0c;在宝塔新建一个网站&#xff0c;域名为 auth.iotheme.cn&#xff0c;设置wordpress伪静态&#xff0c;申请ssl证书。将上面源码解压后上传到此网站根目录。 2. 在宝塔根目录etc下 hosts 中添加 127.0.0.1 auth.iotheme.…

Docker配置Redis集群以及主从扩容与缩容

基础镜像拉取 docker run -p 6379:6379 -d redis:6.0.8 配置文件以及数据卷挂载 # 开启密码验证&#xff08;可选&#xff09; requirepass 1234 # 允许redis外地连接&#xff0c;需要注释掉绑定的IP # bind 127.0.0.1 # 关闭保护模式&#xff08;可选&#xff09; protected-m…

13、SpringBoot 源码分析 - 自动配置深度分析六

SpringBoot 源码分析 - 自动配置深度分析六 refresh和自动配置大致流程AutoConfigurationImportSelector的fireAutoConfigurationImportEvents通知自动配置导入事件AutoConfigurationGroup的selectImports封装成Entry返回MyAutoConfiguration自动配置类创建META-INF文件夹和文件…

CST纳米光学 --- LSPR局部等离子激元共振,消光截面ECS,法诺共振

这期我们用自带的Drude散射粒子&#xff0c;计算消光截面。 查看模型&#xff0c;内核是Silica二氧化硅&#xff0c;正常的介质材料&#xff0c;半径是38纳米&#xff1a; 外围是Drude模型的金属材料包裹&#xff0c;半径48纳米&#xff0c;该材料的参数可由宏Materials->Cr…

多个p标签一行展示,溢出隐藏

一开始&#xff0c;我是让div包裹多个p标签&#xff0c;并让div“flex”布局&#xff0c;且单行溢出隐藏&#xff0c;可是发现当父元素或当前元素有flex时&#xff0c;text-overflow: ellipsis;是不生效的 大多数解决办法都是&#xff0c;不要flex&#xff0c;或者给div下的每个…

代码随想录算法训练营第四十九天 | 139.单词拆分、多重背包、背包问题总结

139.单词拆分 视频讲解&#xff1a; 动态规划之完全背包&#xff0c;你的背包如何装满&#xff1f;| LeetCode&#xff1a;139.单词拆分_哔哩哔哩_bilibili 代码随想录 解题思路 1.dp[i] 字符串的长度为i&#xff0c;dp[i]是否可以被组成 2.递推公式 if( [j,i] && d…

基于springboot开发的Java MES制造执行系统源码,全套源码,一款数字化管理平台源码 云MES系统源码

基于springboot开发的Java MES制造执行系统源码&#xff0c;全套源码&#xff0c;一款数字化管理平台源码 云MES系统源码 MES系统源码相关技术&#xff1a; ​技术架构&#xff1a;springboot vue-element-plus-admin 开发语言&#xff1a;Java 开发工具&#xff1a;idea 前…

【Unity3D小功能】Unity3D中UGUI-Text实现打字机效果

推荐阅读 CSDN主页GitHub开源地址Unity3D插件分享简书地址QQ群&#xff1a;398291828 大家好&#xff0c;我是佛系工程师☆恬静的小魔龙☆&#xff0c;不定时更新Unity开发技巧&#xff0c;觉得有用记得一键三连哦。 一、前言 需求要实现Text的打字机效果&#xff0c;一看居然…