【数据结构】— —查找(折半查找,二叉排序树)

news2025/1/13 7:31:28

🎃个人专栏:

🐬 算法设计与分析:算法设计与分析_IT闫的博客-CSDN博客

🐳Java基础:Java基础_IT闫的博客-CSDN博客

🐋c语言:c语言_IT闫的博客-CSDN博客

🐟MySQL:数据结构_IT闫的博客-CSDN博客

🐠数据结构:​​​​​​数据结构_IT闫的博客-CSDN博客

💎C++:C++_IT闫的博客-CSDN博客

🥽C51单片机:C51单片机(STC89C516)_IT闫的博客-CSDN博客

💻基于HTML5的网页设计及应用:基于HTML5的网页设计及应用_IT闫的博客-CSDN博客​​​​​​

🥏python:python_IT闫的博客-CSDN博客

欢迎收看,希望对大家有用!

目录

🎯目的:

🎯内容:

🎯环境:

🎯步骤:

🥏折半查找:

 💛主要代码解析:

💻完整代码:

 🥏二叉排序树:

 💛主要代码解析:

 💻完整代码:


🎯目的:

1、掌握查找的特点。

2、掌握折半查找的基本思想及其算法。

3、熟悉二叉排序树的特点,掌握二叉排序树的插入、删除操作。

🎯内容:

1、设有关键字序列,使用折半查找的方法查找关键字是否存在。

2、根据关键字序列构造二叉排序树,并完成插入、删除关键字的操作。

🎯环境:

TC或VC++。

🎯步骤:

🥏折半查找:

 💛主要代码解析:

  1. #include <iostream>#include <string>#include <vector>:这些是预处理指令,用于引入标准库的头文件,以便在程序中使用相应的功能。

  2. using namespace std;:这是一个命名空间的声明,它允许在代码中直接使用std命名空间中的标识符,而无需在前面加上std::前缀。

  3. typedef string KeyType;typedef int InfoType;:这些是类型定义语句,用于给已有类型(string和int)起别名,便于在代码中使用。

  4. struct ElemType { ... };:这是一个结构体定义,用于表示数据元素类型。每个数据元素包含一个关键字和其他信息域。

  5. struct SeqList { ... };:这是一个结构体定义,用于表示顺序表类型。顺序表包含一个存储空间的基地址和当前长度。

  6. int binary_search(SeqList& list, int target_score) { ... }:这是一个折半查找函数的定义,用于在顺序表中查找目标成绩,并返回其位置。函数使用二分法进行查找。

  7. int main() { ... }:这是程序的主函数,程序从这里开始执行。

  8. 创建顺序表并初始化:程序中创建了一个顺序表对象list,通过new运算符动态分配了一个能容纳6个数据元素的数组,并将其地址赋给list.R,同时设置list.length为6。该顺序表存储了6个学生的姓名和成绩信息。

  9. 输出所有学生成绩:通过for循环遍历顺序表中的所有数据元素,并使用cout流输出每个学生的姓名和成绩信息。

  10. 从键盘输入要查找的成绩:使用cin流从控制台接收用户输入的目标成绩。

  11. 调用折半查找函数进行查找:调用binary_search函数,在顺序表中使用折半查找算法查找与目标成绩匹配的学生信息,并返回其位置。

  12. 根据查找结果输出相应信息:根据查找的结果,使用条件语句判断是否找到了匹配的学生信息,并将结果输出到控制台。

  13. 从键盘输入要查找的姓名:使用cin流从控制台接收用户输入的目标姓名。

  14. 在顺序表中查找姓名:通过for循环遍历顺序表中的所有数据元素,查找与目标姓名匹配的学生信息,并记录其位置。

  15. 根据查找结果输出相应信息:根据查找的结果,使用条件语句判断是否找到了匹配的学生信息,并将结果输出到控制台。

(1)使用顺序存储法存储若干个学生的成绩,例如:从键盘输入ava 35 , emy 57 , jack 62 , lily 71 , lucy 83 , mary 90,并输出其值;

(2)从键盘输入71,查找是否存在该成绩,若存在,则输出该成绩对应在表中的所有信息,否则给出查找失败的信息;

(3)从键盘输入nancy,查找是否存在该姓名,若存在,则输出该姓名对应在表中的所有信息,否则给出查找失败的信息。

💻完整代码:

/*如果此程序运行不成功,请您做以下操作
 工具–编译选项—编译器
勾选编译时加入以下命令
并加入下面代码:-std=c++11
 */
#include <iostream>
#include <string>
#include <vector>

using namespace std;

typedef string KeyType;
typedef int InfoType;

// 数据元素类型定义
struct ElemType {
    KeyType key;        // 关键字域
    InfoType otherinfo; // 其他域
};

// 顺序表的定义
struct SeqList {
    ElemType* R;   // 储存空间的基地址
    int length;    // 当前长度
};

// 折半查找函数,返回查找到的位置,若未找到,返回 -1
int binary_search(SeqList& list, int target_score) {
    int left = 0;
    int right = list.length - 1;
    while (left <= right) {
        int mid = (left + right) / 2;
        if (list.R[mid].otherinfo == target_score) {
            return mid;
        } else if (list.R[mid].otherinfo < target_score) {
            left = mid + 1;
        } else {
            right = mid - 1;
        }
    }
    return -1;
}

int main() {
    // 从键盘输入若干个学生成绩,并将其存储在顺序表中
    SeqList list = {new ElemType[6], 6};
    list.R[0] = {"ava", 35};
    list.R[1] = {"emy", 57};
    list.R[2] = {"jack", 62};
    list.R[3] = {"lily", 71};
    list.R[4] = {"lucy", 83};
    list.R[5] = {"mary", 90};

    // 输出所有学生成绩
    cout << "所有学生成绩:\n";
    for (int i = 0; i < list.length; ++i) {
        cout << list.R[i].key << " " << list.R[i].otherinfo << endl;
    }
    cout << endl;

    // 从键盘输入要查找的成绩
    int target_score;
    cout << "请输入要查找的成绩:";
    cin >> target_score;

    // 查找成绩为 target_score 的学生信息并输出
    int pos = binary_search(list, target_score);
    if (pos != -1) {
        cout << "成绩为 " << target_score << " 的学生信息:\n";
        cout << list.R[pos].key << " " << list.R[pos].otherinfo << endl;
    } else {
        cout << "未找到成绩为 " << target_score << " 的学生信息\n";
    }
    cout << endl;

    // 从键盘输入要查找的姓名
    string target_name;
    cout << "请输入要查找的姓名:";
    cin >> target_name;

    // 查找姓名为 target_name 的学生信息并输出
    pos = -1;
    for (int i = 0; i < list.length; ++i) {
        if (list.R[i].key == target_name) {
            pos = i;
            break;
        }
    }
    if (pos != -1) {
        cout << "姓名为 " << target_name << " 的学生信息:\n";
        cout << list.R[pos].key << " " << list.R[pos].otherinfo << endl;
    } else {
        cout << "未找到姓名为 " << target_name << " 的学生信息\n";
    }

    return 0;
}

 🥏二叉排序树:

 💛主要代码解析:

这段代码是关于二叉排序树的实现。下面是对代码的解析:

1. 定义了三个类型:
   - KeyType:表示关键字的类型,这里定义为int。
   - InfoType:表示其他数据项的类型,这里定义为int。
   - ElemType:表示二叉排序树中每个节点的数据域类型,包括一个关键字项和其他数据项。

2. 定义了二叉排序树的节点结构BSTNode,包括数据域data和左右孩子指针lchild、rchild。

3. 定义了二叉排序树的指针类型BSTree,即指向BSTNode的指针。

4. 实现了二叉树的插入操作InsertBST:
   - 如果二叉树为空,则生成一个新的节点S,并将关键字key赋值给S的data.key,然后将S作为叶子节点插入到树中。
   - 如果key小于当前节点的关键字,则在左子树上继续递归地插入。
   - 如果key大于当前节点的关键字,则在右子树上继续递归地插入。

5. 实现了二叉树的创建操作CreatBST:
   - 首先将树T初始化为空树。
   - 然后依次读入关键字为key的节点,将每个节点插入到二叉排序树T中,直到输入-1结束。

6. 实现了二叉树的查找操作SearchBST:
   - 如果当前节点为空或者当前节点的关键字等于要查找的关键字key,则返回当前节点的指针。
   - 如果key小于当前节点的关键字,则在左子树上继续递归地查找。
   - 如果key大于当前节点的关键字,则在右子树上继续递归地查找。

7. 实现了中序遍历操作InOrderTraverse:
   - 如果当前节点不为空,先递归遍历左子树,然后输出当前节点的关键字,最后递归遍历右子树。

8. 在主函数main中:
   - 创建一个空的二叉排序树T,并通过CreatBST函数将输入的整数构建成二叉排序树。
   - 输出中序遍历结果。
   - 插入数据元素13,并再次输出中序遍历结果。
   - 查找数据元素37,如果不存在则插入,并输出结果。
   - 查找数据元素20,如果不存在则插入,并输出结果。
   - 最后输出查找37和20后的中序遍历结果。

总结:这段代码实现了二叉排序树的插入、创建、查找和中序遍历操作。它可以构建一个有序的二叉树,并能够快速查找和插入元素。

(1)二叉排序树结点定义;

(2)从键盘上输入六个整数45、24、53、12、37、9构造二叉排序树;

(3)输出其中序遍历结果;

(4)插入数据元素13,输出其中序遍历结果;

(5)查找数据37和20是否存在,若存在输出提示,若不存在,则将该数据插入二叉排序树中;

 💻完整代码:

#include "iostream"
using namespace std;
typedef int KeyType;
typedef int InfoType;
typedef int Elemtype;

//二叉排序树的二叉链表储存表示
typedef struct{
	KeyType key;//关键字项 
	InfoType otherinfo;//其他数据项 
}ElemType;//每个结点的数据域的类型
typedef struct BSTNode{
	ElemType data;//每个结点的数据域包括关键字和其他数据域
	struct BSTNode *lchild,*rchild;//左右孩子指针 
}BSTNode,*BSTree;

//二叉树的插入
void InsertBST(BSTree &T,KeyType key){
	//当二叉树不存在关键字等于e.key时,则插入
	if(!T){
		BSTree S;
		S=new BSTNode;//生成新的结点*S
		S->data.key=key;
		S->lchild=S->rchild=NULL;//把结点S作为叶子结点
		T=S;//把S插入到找到的位置 
	} 
	else if(key<T->data.key)
		InsertBST(T->lchild,key);//插入到左子树 
	else if(key>T->data.key)
		InsertBST(T->rchild,key);//插入到右子树 
} 

//二叉树的创建
void CreatBST(BSTree &T){//依次读入关键字为的结点,将相应的结点插入到二叉排序树T中
	T=NULL;//将二叉排序树T初始化为空树
	ElemType e;
	cin>>e.key;
	while(e.key!=-1){//以-1结束 
		InsertBST(T,e.key);
		cin>>e.key;
	} 
}

//二叉树的查找 
BSTree SearchBST(BSTree T,KeyType key){
	//查找成功,返回节点指针:查找失败,返回空指针 
	if((!T)||key==T->data.key) 
		return T;//如果为空树或查找成功
	else if(key<T->data.key)
		return SearchBST(T->lchild,key);//在左子树上找 
	else
		return SearchBST(T->rchild,key);//在右子树上找 
}

void InOrderTraverse(BSTree T){//中序遍历输出
	if(T){
		InOrderTraverse(T->lchild);//遍历左子树 
		cout<<T->data.key<<" ";
		InOrderTraverse(T->rchild);//遍历右子树 
	} 
}

int main(){
	BSTree T; 
	KeyType key;
	ElemType e;
	cout<<"请您输入整数构建二叉排序树(以-1结尾)"<<endl; 
	CreatBST(T);
	cout<<"中序遍历为:"<<endl;
	InOrderTraverse(T);
	cout<<"\n插入数据元素13后,遍历结果为:"<<endl;
	InsertBST(T,13);
	InOrderTraverse(T);
	if(!SearchBST(T,37)){
		cout<<"\n数据元素37不存在,已将其插入树中"<<endl; 
		InsertBST(T,37);
	}else{
		cout<<"\n数据元素37已存在"<<endl; 
	}
	if(!SearchBST(T,20)){
		cout<<"数据元素20不存在,已将其插入树中"<<endl;
		InsertBST(T,20);
	}else{
		cout<<"\n数据元素20已存在"<<endl;
	}
	cout<<"查找37和20后,遍历结果为:"<<endl;
	InOrderTraverse(T);
}

 

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

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

相关文章

数据结构-二叉树·堆(顺序结构的实现)

&#x1f389;个人名片&#xff1a; &#x1f43c;作者简介&#xff1a;一名乐于分享在学习道路上收获的大二在校生 &#x1f43b;‍❄个人主页&#x1f389;&#xff1a;GOTXX &#x1f43c;个人WeChat&#xff1a;ILXOXVJE&#x1f43c;本文由GOTXX原创&#xff0c;首发CSDN&…

游戏推荐《塞尔达传说王国之泪》

塞尔达传说&#xff1a;王国之泪 播报编辑讨论12上传视频 2023年任天堂企划制作本部开发的动作冒险游戏 《塞尔达传说 王国之泪》是任天堂企划制作本部开发的动作冒险游戏&#xff0c;为《塞尔达传说》主系列的第20作、《塞尔达传说&#xff1a;旷野之息》的正统续篇&#xf…

块级作用域的理解

块级作用于的概念 由一对花括号{}中的语句集都属于一个块&#xff0c;在这个{}里面包含的块内定义的所有变量在代码块外都是不可见的&#xff0c;因此称为块级作用域。 作用域永远都是任何一门语言的重中之中&#xff0c;因为它控制着变量和参数的可见性和生命周期。讲到这里&…

uniapp打包安卓app后获取签名证书的SHA1,SHA256,MD5等信息

获取签名证书信息的方法有两种 1.dcloud开发者中心生成证书查看 在证书详情中可以查看&#xff0c;还可以下载证书 2.使用命令查看 1.先安装jre8&#xff0c;再配置一下环境变量 jre8下载地址 2.将打好的正式版app 后缀改为 .zip&#xff0c;解压 3.打开META-INF目录&…

基于卷积神经网络的抗压强度预测,基于卷积神经网络的抗折强度预测

目录 背影 卷积神经网络CNN的原理 卷积神经网络CNN的定义 卷积神经网络CNN的神经元 卷积神经网络CNN的激活函数 卷积神经网络CNN的传递函数 卷积神经网络CNN抗压强度预测 完整代码:基于卷积神经网络的抗压强度和抗折强度预测,基于CNN的抗压强度和抗折强度预测(代码完整,数据…

搭建第一个区块链网络与一键部署WeBASE步骤

官网 搭建第一个区块链网络 — FISCO BCOS v2 v2.9.0 文档 (fisco-bcos-documentation.readthedocs.io) 一键部署 — WeBASE v1.5.5 文档 (webasedoc.readthedocs.io) 步骤 默认如MySQL、Python、java等依赖已经引入 1.创建操作目录, 下载安装脚本 创建操作目录 cd ~ &a…

Hydra post登录框爆破

文章目录 无token时的Hydra post登录框爆破带Token时的Hydra post登录框爆破 无token时的Hydra post登录框爆破 登录一个无验证码和token的页面&#xff0c;同时抓包拦截 取出发送数据包&#xff1a;usernameadb&password133&submitLogin 将用户名和密码替换 userna…

安科瑞变电站综合自动化系统在青岛海洋科技园应用

安科瑞 耿敏花 摘 要&#xff1a;变电站综合自动化系统是将变电站内的二次设备经过功能的组合和优化设计&#xff0c;利用先进的计算机技术、通信技术、信号处理技术&#xff0c;实现对全变电站的主要设备和输、配电线路的自动监视、测量、控制、保护、并与上级调度通信的综合性…

教你怎么用Python每天自动给女朋友免费发短信

今天的教程就是教大家怎么发送免费短信给女朋友。 发送短信接口&#xff0c;我知道的常见的有两个平台&#xff0c;一个是 twilio&#xff0c;可以免费发短信 500 条&#xff0c;可发任意信息&#xff0c;一个是腾讯云&#xff0c;可以免费发短信 100 条&#xff0c;需要申请短…

【C语言初阶】函数

目录 一、函数是什么 二、C语言中函数的分类 2.1 库函数&#xff1a; strcpy memset 2.2 自定义函数 三、函数的参数 3.1 实际参数&#xff08;实参&#xff09; 3.2 形式参数&#xff08;形参&#xff09; 四、函数的调用 4.1 传值调用 4.2 传址调用 五、函数的嵌…

【广州华锐互动】VR历史古城复原:沉浸式体验古代建筑,感受千年风华!

在科技日新月异的今天&#xff0c;虚拟现实&#xff08;VR&#xff09;技术已经成为了我们生活中不可或缺的一部分。从娱乐游戏到医疗健康&#xff0c;从教育培训到房地产销售&#xff0c;VR技术的应用领域日益广泛。而近年来&#xff0c;VR技术在文化遗产保护和古迹复原方面的…

警惕Mallox勒索病毒的最新变种mallox,您需要知道的预防和恢复方法。

尊敬的读者&#xff1a; 在这个数字时代&#xff0c;恶意软件不再是仅限于技术领域的威胁&#xff0c;而是每个人都可能面临的潜在风险。其中&#xff0c;.mallox勒索病毒崭露头角&#xff0c;它不仅能够以不可思议的方式加密您的数据&#xff0c;还能要求您支付赎金以获取解密…

行业观察:数字化企业需要什么样的数据中心

伴随着数字经济在中国乃至全球的高速发展&#xff0c;数字化转型已经成为广大企业的必经之路。而作为数字经济的核心基础设施&#xff0c;数据中心充当了接收、处理、存储与转发数据流的“中枢大脑”&#xff0c;对驱动数字经济发展和企业数字化转型起到了极为关键的重要作用。…

vue中的rules表单校验规则使用方法 :rules=“rules“

一、el-form里面必写属性值 :ref"dataForm" // 提交表单时进行校验 :rules"rules" // return 下的校验规则 :model"userForm" // 绑定表单的值 <el-formref"dataForm" // 必写属性值:rules"rules"…

通过在Z平面放置零极点的来设计数字滤波器

文章来源地址&#xff1a;https://www.yii666.com/blog/393376.html 通过在Z平面放置零极点的来设计数字滤波器 要求&#xff1a;设计一款高通滤波器&#xff0c;用在音频信号处理过程中&#xff0c;滤掉100Hz以下的信号。 实现方法&#xff1a;通过在Z平面放置零极点的来设…

(景行锐创) 高性能计算平台 Pytorch 深度学习环境超详细教程

文章目录 前言1. 账号申请2. 登录高算平台网站3. 安装 Xshell&#xff0c;Xftp 软件4. 连接高算平台5. 安装 Anaconda6. 安装 CUDA7. 配置 cuDNN8. 安装 torch 和 torchvision9. 提交作业测试10. 解压与压缩文件11. 其他结语 前言 目前一些学校为了便于师生进行大规模的计算任…

Aop自定义注解生成日志

Aop自定义注解生成日志 1.编写自定义注解 //表示此注解可以标注在方法上 Target(ElementType.METHOD) //运行时生效 Retention(RetentionPolicy.RUNTIME) public interface OpetionLog {//定义一个变量&#xff0c;可以接收参数String value() default "";}2.Cont…

Leetcode 剑指 Offer II 051. 二叉树中的最大路径和

题目难度: 困难 原题链接 今天继续更新 Leetcode 的剑指 Offer&#xff08;专项突击版&#xff09;系列, 大家在公众号 算法精选 里回复 剑指offer2 就能看到该系列当前连载的所有文章了, 记得关注哦~ 题目描述 路径 被定义为一条从树中任意节点出发&#xff0c;沿父节点-子节…

微信CRM系统在电商行业的应用

随着移动互联网的快速发展&#xff0c;微信已经成为电商行业重要的营销和客户服务渠道。然而&#xff0c;如何在海量的微信消息中保持客户沟通、提升客户体验、实现精准营销&#xff0c;是电商行业面临的一大挑战。微信CRM系统作为一种新型的客户关系管理工具&#xff0c;可以有…

【qemu逃逸】HWS2017-FastCP

前言 虚拟机用户名&#xff1a;root 虚拟机密码&#xff1a;无密码 本题有符号&#xff0c;所以对于设备定位啥的就不多说了&#xff0c;直接逆向设备吧。 设备逆向 在 realize 函数中设置一个时钟任务&#xff0c;并且可以看到只注册了 mmio&#xff0c;大小为 0x100000。…