数据结构与算法-静态查找表

news2024/12/28 4:53:34

在这里插入图片描述
🌞 “清醒 自律 知进退!”

查找

  • 🎈1.查找的相关概念
  • 🎈2.静态查找表
    • 🔭2.1静态查找表的类定义
    • 🔭2.2顺序查找
    • 🔭2.3二分查找
      • 🔎二分查找例题
    • 🔭2.4分块查找
    • 🔭2.5三种算法的比较分析

查找是在一些有序的或无序的数据元素中,通过一定的方法找出与给定关键字相同的数据元素的过程,即根据给定的某个值在查找表中确定一个关键字等于给定的记录或数据元素。查找是信息处理科学中十分重要的操作。

🎈1.查找的相关概念

  1. 查找表是同一类型数据元素(或记录)构成的集合,与4种数据关系中的集合结构对应。由于集合中数据元素之间存在着完全松散的关系。因此,查找表往往要借助其他数据结构来实现相关算法。
  2. 关键字是可以标识一个数据元素(或记录)的数据项,关键字的值被称之为键值。若关键字可以唯一地标识一条记录,则称此关键字为主关键字。
  3. 查找是根据给定的某个值,在查找表中确定一个关键字等于给定值的记录或数据元素的过程。若在查找表中存在与给定值匹配的记录,则查找成功,此时查找的结果可以是整个记录的信息或查找成功标记等。若在查找表中不存在与给定值匹配的记录,则查找不成功,此时查找结果可以是不成功标记,或将被查找记录插入查找表。
  4. 静态查找表是仅对表进行查找操作,而不进行插入和删除操作的查找表。静态查找在查找不成功时,只返回一个不成功标志,不改变查找表,因此表中数据元素的数量不会发生变化。
  5. 动态查找表是在查找的同时对表进行插入和删除操作的表。动态查找在查找不成功时,需要将被查找的记录插入查找表,因此表中数据元素的数量可能会发生变化。
    在这里插入图片描述

🎈2.静态查找表

🔭2.1静态查找表的类定义

#define _CRT_SECURE_NO_WARNINGS 1
#define Max 100
#include <iostream>
using namespace std;
typedef int KeyType;
typedef int InfoType;
typedef int IndexType;
typedef struct 
{
	KeyType key;//KeyType为关键字数据类型
	InfoType otherinfo;//其他域
}SElemType;
class StaticSearchtable
{
private:
	SElemType* elem;
	int length;
public:
	StaticSearchtable()//构造函数,0位留空
	{
		elem = new SElemType[Max + 1];
		length = 0;
	}
	~StaticSearchtable()//析构函数,释放存储空间
	{
		delete[]elem;
		length = 0;
	}
	void Create(int n)//创建n个元素的顺序表
	{
		for (int i = 0; i <= n; i++)
		{
			cin >> elem[i].key >> elem[i].otherinfo;
		}
		length = n;
	}
	int SqSearch(KeyType key);//顺表表查找值等于key的关键字
	int BinSearch(KeyType key);//二分查找值等于key的关键字
	int IndexSearch(IndexType index[Max], KeyType key, int b);//分块查找值等于key的关键字,b为块数
};

🔭2.2顺序查找

🔎顺序查找的主要思想

  1. 设立哨兵位elem[0].key=key,其作用是防止扫描溢出。
  2. 从表的末端开始向左扫描线性表,依次将扫描到的关键字值和给定值key进行比较,若找到关键字,则查找成功,返回该关键字在顺序表中的下标;否则查找失败,返回0.
int StaticSearchtable::SqSearch(KeyType key)
{
	elem[0].key = key;//哨兵位
	int i = 0;
	for (i = length; elem[i].key != key; i--)//从末端开始向左扫描
	{
		;//空语句
	}
	return i;
}

🔎顺序查找分析:
在这里插入图片描述

🔭2.3二分查找

二分查找又称折半查找,它是一种效率较高的查找方法。二分查找要求线性表采用顺序存储结构且元素有序。类似于顺序查找方法,在存储元素时,数组元素第0位留空。

🔎二分查找的主要思想是每次将待查找记录所在的区间缩小一 半。具体步骤如下:设elem[low..high]是当前的查找区间,首先确定中间点位置mid = [(low+high)/2],然后将待查元素的关键字key值与elem[mid].key比较:(初始时,令low=1,high=length

  1. mid = [(low+high)/2]
  2. key==elem[mid].key,则查找成功,返回mid,即该元素在顺序表中的下标。
  3. key<elem[mid].key,则high = mid-1
  4. key>elem[mid].key,则low = mid+1
  5. 重复上述操作,直至low>high时,查找失败,此时返回0
int StaticSearchtable::BinSearch(KeyType key)
{
	int low = 1,high = length;
	int mid;
	while (low <= high)
	{
		mid = (low + high) / 2;
		if (key == elem[mid].key)
			return mid;
		else if (key < elem[mid].key)
			high = mid - 1;
		else
			low = mid + 1;
	}
	return 0;
}

✅二分查找过程可用二叉树来描述,在构造二叉树的过程中,把当前查找区间的中点位置上的元素作为树根,左子表和右子表的元素分别作为根的左子树和右子树。由此递归得到二叉树,通常称描述查找的过程的二叉树为判定树。判定树的形态与表中个数n相关,与输入示例中的key值无关。

例如,要找到15个数据元素的有序表中的第8个元素仅需比较1次,找到第4和第12个元素需要比较2次,找到第2,6,1014个元素需要比较3次;找到第1,3,5,7,9,11,1315个元素需要比较4次。其查找过程如图所示,树中的每个圆圈结点表示表中一个元素,结点中的值表示该元素在表中的位置;圆圈结点表示查找成功,方框结点表示查找失败。若查找失败,则比较过程是一条从判定树的根到某结点的路径,所需关键字比较次数是该路径上圆圈结点的个数。
在这里插入图片描述

🔎二分查找分析:

  1. 判定树为满二叉树:(有序表元素个数为:n=2h-1
    (1).查找成功时平均查找长度:
    在这里插入图片描述
    (2).查找不成功时平均查找长度:h

  2. 判定树为非满二叉树:

(1).查找成功时平均查找长度:
在这里插入图片描述
(2).查找不成功时平均查找长度:
在这里插入图片描述

🔎二分查找例题

例:给定18个元素的有序表 {2,5,8,10,15,40,42,55,66,70,72,75,80,88,90,100,108,200},采用二分查找,试问:
(1).查找长度为4和5的元素个数分别有多少个?
(2).若要查找值为15的数据元素,要经过多少次比较?依次与哪些元素进行比较?
(3).在查找概率相等的情况下,计算查找成功和查找不成功的平均查找长度。
在这里插入图片描述
:第一问可以直接数第四行和第五行元素的个数:分别是8和3.
第二问数这条路径圆圈结点的个数为比较次数,圆圈内的值为比较的数:
在这里插入图片描述
因此,我们需要进行4次比较,依次与表中的元素66,10,40,15比较。
第三问,在查找概率相等的情况下,查找成功的平均查找长度为:
(11+22+43+84+35)/18=32/9
查找不成功的平均查找长度为:(4
13+5*6)/19=82/19

🔭2.4分块查找

🔎 分块查找又称索引顺序查找,它是顺序表查找的一种改进方法,其性能介于顺序查找和二分查找之间。在索引查找方法中,除存储表本身以外,还需存储一个索引表。存储方法如下:

  1. 将线性表elem[1..n]均分为b块,前b-1块中元素个数为s=[n/b],最后一块即b块的元素个数小于等于s.
  2. 每一块中的关键字不一定有序,但前一块中的最大关键字小于后一块中的最小关键字,即块内无序,块间有序
  3. 抽取各块的最大关键字及起始位置构成一个索引表index[0..b-1],即index[i](0<=i<=b-1)中存放第i块的最大关键字和该块在表中的初始位置。

📖索引表的数据类型定义:

typedef struct
{
	KeyType key;
	int link;
}IndexType;

📖分块查找的算法:

int StaticSearchtable::IndexSearch(IndexType index[Max], KeyType key, int b)
{//b为块数
	int low = 0, high = b - 1, mid, i, s;
	if (length % b == 0)
		s = length / b;
	else
		s = length / b + 1;
	while (low <= high)
	{
		mid = (low + high) / 2;
		if (index[mid].key >= key)
			high = mid - 1;
		else
			low = mid + 1;
	}
	//在索引表high+1快对应的线性表中顺序查找key
	i = index[high + 1].link;
	while (i <= index[high + 1].link + s - 1 && elem[i].key != key)
	{
		i++;
	}
	if (i <= index[high + 1].link + s - 1)
		return i;//查找成功,返回该元素的下标
	else
		return 0;//查找失败,返回0
}

🔭2.5三种算法的比较分析

  1. 顺序查找的时间复杂度最差,二分查找的时间复杂度最好,分块查找的时间复杂度介于两种之间。
  2. 分块查找需要增加索引数据的空间,空间复杂度最大。
  3. 顺序查找对表没有特殊要求。
  4. 分块查找的数据块之间在物理上可以不连续,插入、删除数据只涉及对应的块,但增加了索引的维护。
  5. 二分查找要求表有序,若表的元素插入与删除很频繁,则维持有序的工作量极大。
  6. 在表不大的时候,一般使用顺序查找。

🌞运行示例:

#define _CRT_SECURE_NO_WARNINGS 1
#define Max 100
#include <iostream>
using namespace std;
typedef int KeyType;
typedef int InfoType;
typedef struct
{
	KeyType key;//KeyType为关键字数据类型
	InfoType otherinfo;//其他域
}SElemType;
typedef struct
{
	KeyType key;
	int link;
}IndexType;
class StaticSearchtable
{
private:
	SElemType* elem;
	int length;
public:
	StaticSearchtable()//构造函数,0位留空
	{
		elem = new SElemType[Max + 1];
		length = 0;
	}
	~StaticSearchtable()//析构函数,释放存储空间
	{
		delete[]elem;
		length = 0;
	}
	void Create(int n)//创建n个元素的顺序表
	{
		for (int i = 0; i <= n; i++)
		{
			cout << "输入第" << i+1 << "个元素的值和下标:";
			cin >> elem[i].key >> elem[i].otherinfo;
		}
		length = n;
	}
	int SqSearch(KeyType key);//顺表表查找值等于key的关键字
	int BinSearch(KeyType key);//二分查找值等于key的关键字
	int IndexSearch(IndexType index[Max], KeyType key, int b);//分块查找值等于key的关键字,b为块数
};
int StaticSearchtable::SqSearch(KeyType key)
{
	elem[0].key = key;//哨兵位
	int i = 0;
	for (i = length; elem[i].key != key; i--)//从末端开始向左扫描
	{
		;//空语句
	}
	if (i >= 0)
		cout << "该数所在顺序表中的下标为:" << i << endl;
	else
		cout << "未找到!" << endl;
	return 0;
}
int StaticSearchtable::BinSearch(KeyType key)
{
	int low = 1, high = length;
	int mid;
	while (low <= high)
	{
		mid = (low + high) / 2;
		if (key == elem[mid].key)
		{
			cout << "该数经二分查找下标为:" << mid << endl;
			break;
		}
		else if (key < elem[mid].key)
			high = mid - 1;
		else
			low = mid + 1;
	}
	if(low>high)
		cout << "未找到!" << endl;
	return 0;
}
int StaticSearchtable::IndexSearch(IndexType index[Max], KeyType key, int b)
{//b为块数
	int low = 0, high = b - 1, mid, i, s;
	if (length % b == 0)
		s = length / b;
	else
		s = length / b + 1;
	while (low <= high)
	{
		mid = (low + high) / 2;
		if (index[mid].key >= key)
			high = mid - 1;
		else
			low = mid + 1;
	}
	//在索引表high+1快对应的线性表中顺序查找key
	i = index[high + 1].link;
	while (i <= index[high + 1].link + s - 1 && elem[i].key != key)
	{
		i++;
	}
	if (i <= index[high + 1].link + s - 1)
		return i;//查找成功,返回该元素的下标
	else
		return 0;//查找失败,返回0
}
int main()
{
	StaticSearchtable a;
	a.Create(8);
	a.SqSearch(6);
	a.BinSearch(7);
	return 0;
}

在这里插入图片描述

好啦,关于静态查找表的知识到这里就先结束啦,后期会继续更新学习数据结构与算法的相关知识,欢迎大家持续关注、点赞和评论!❤️❤️❤️

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

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

相关文章

SQL面试题,判断if的实战应用

有如下表&#xff0c;请对这张表显示那些学生的成绩为及格&#xff0c;那些为不及格 1、创建表&#xff0c;插入数据 CREATE TABLE chapter8 (id VARCHAR(255) NULL,name VARCHAR(255) NULL,class VARCHAR(255) NULL,score VARCHAR(255) NULL );INSERT INTO chapter8 (id, n…

非应届生简历模板13篇

无论您是职场新人还是转行求职者&#xff0c;一份出色的简历都是获得心仪岗位的关键。本文为大家精选了13篇专业的非应届生简历模板&#xff0c;无论您的经验如何&#xff0c;都可以灵活参考借鉴&#xff0c;提升自己的简历质量。让简历脱颖而出&#xff0c;轻松斩获心仪职位&a…

02数仓平台Zookeeper

概述 ZooKeeper是一种分布式协调服务&#xff0c;用于管理大型主机集。在分布式环境中协调和管理服务是一个复杂的过程。ZooKeeper通过其简单的架构和API解决了这个问题。ZooKeeper允许开发人员专注于核心应用程序逻辑&#xff0c;而不必担心应用程序的分布式性质。 Zookeepe…

Dart编程基础 - 一种新的编程语言

Dart编程基础 – 一种新的编程语言 Dart Programming Essentials - A New Type of Programming Language By JacksonML Dart is a client-optimized language for fast apps on any platform From dart.dev 在1999年之前&#xff0c;和我一样对计算机技术感兴趣的伙伴们&…

高级算法设计与分析练习1-10

文章目录 7-1 锦标赛7-2 选我啊&#xff01;7-3 朋友圈7-4 最短路径7-5 ICPC保定站7-6 填数字7-7 Werewolf7-8 球队“食物链”7-9 代码排版7-10 至多删三个字符 7-1 锦标赛 HBU有2 n名ACM选手&#xff0c;编号依次为1−2 n。他们现在要进行一场程序设计比赛&#xff0c;这个比…

规则引擎专题---1、什么是规则引擎

什么是规则引擎&#xff0c;为了更易大家理解&#xff0c;我们这边先抛出一个问题。 问题 现有一个在线申请信用卡的业务场景&#xff0c;用户需要录入个人信息&#xff0c;如下图所示&#xff1a; 通过上图可以看到&#xff0c;用户录入的个人信息包括姓名、性别、年龄、学…

基于51单片机的交通灯_可调时间_夜间+紧急模式

51单片机交通灯 1 讲解视频&#xff1a;2 功能要求3 仿真图&#xff1a;4 原理图PCB5 实物图6 程序设计&#xff1a;7 设计报告8 资料清单&#xff08;提供资料清单所有文件&#xff09;&#xff1a;设计资料下载链接&#xff1a; 51单片机简易交通灯_可调时间_夜间紧急 仿真代…

三、Linux高级命令

目录 1、重定向命令 1.1 重定向 > 1.2 重定向 >> 该章节的所有操作都在/export/data/shell目录进行&#xff0c;请提前创建该目录。 mkdir -p /export/data/ 1、重定向命令 1.1 重定向 > Linux 允许将命令执行结果重定向到一个文件&#xff0c;本应显示在…

「Verilog学习笔记」自动贩售机1

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点&#xff0c;刷题网站用的是牛客网 自动贩售机中可能存在的几种金额&#xff1a;0&#xff0c;0.5&#xff0c;1&#xff0c;1.5&#xff0c;2&#xff0c;2.5&#xff0c;3。然后直接将其作为状态机的几种状…

HTTP 基本概念(计算机网络)

一、HTTP 是什么&#xff1f; HTTP(HyperText Transfer Protocol) &#xff1a;超文本传输协议。 HTTP 是一个在计算机世界里专门在「两点」之间「传输」文字、图片、音频、视频等「超文本」数据的「约定和规范」。 「HTTP 是用于从互联网服务器传输超文本到本地浏览器的协议…

接口测试工具:Jmeter详解

安装 使用JMeter的前提需要安装JDK&#xff0c;需要JDK1.7以上版本 目前在用的是JMeter5.2版本&#xff0c;大家可自行下载解压使用 运行 进入解压路径如E: \apache-jmeter-5.2\bin&#xff0c;双击jmeter.bat启动运行 启动后默认为英文版本&#xff0c;可通过Options – C…

仿真的整体框架和类图设计

之前的写的模拟代码没有模块&#xff0c;没有对象&#xff0c;写的逻辑结构也很混乱。我花了些时间进行整理&#xff0c;首先所有的类如下图 在管理类中有统一的管理类的接口 &#xff0c;提供所有管理类的虚拟初始化和关闭方法 然后事件的管理类 我希望在这个类中管理所有的脉…

匿名结构体类型、结构体的自引用、结构体的内存对齐以及结构体传参

文章目录 &#x1f680;前言&#x1f680;结构体✈️结构体类型的声明✈️结构体变量的创建与初始化✈️结构体类型的特殊声明✈️结构体的自引用✈️结构体的内存对齐&#x1f681;修改默认对齐数 ✈️结构体传参 &#x1f680;前言 在C语言中有着各种数据类型&#xff0c;这…

服务注册发现 配置中心 springcloud alibaba nacos

文章目录 0100 系统环境0200 nacos安装0201 下载0202 安装 0300 工程说明0301 结构说明0302 运行效果 0400 代码说明0401 服务提供者&#xff08;Provider Service&#xff09;0402 服务消费者&#xff08;Consumer Service&#xff09;服务提供者SDK&#xff08;Provider Serv…

应用商店优化之利用季节性提高应用曝光

在应用商店中利用季节性优化&#xff0c;是提高应用和游戏的曝光度以及应用商店转化率的最有效策略之一。 1、季节性的影响。 用户消费来自许多不同渠道的新闻和信息&#xff0c;这会影响他们做出决策的方式。比如在节日期间&#xff0c;当用户寻找购物类型的应用时&#xff0…

springboot数据格式验证——自定义日期格式验证及list验证

我们在工作中经常需要对日期格式进行定义&#xff0c;如果客户端传来的日期字符串不符合要求&#xff0c;那么根本无法保存&#xff0c;但是已有的注解并没有日期格式的验证&#xff0c;那我们就自己实现一个 一、自定义日期格式验证的注解DateFormat import javax.validatio…

Linux--初识和基本的指令(3)

目录 1.前言 1.指令 1.1 cat指令 1.2 echo指令 1.3 more 指令 1.4 less指令 1.5 什么时候使用less和more 1.6 head指令 1.7 tail指令 1.8 wc指令 1.9 与时间相关的指令 1.9.1 date指令 1.9.2 cal指令 1.10 16.find指令&#xff1a;&#xff08;灰常重要&#x…

熬夜会秃头——beta冲刺Day7

这个作业属于哪个课程2301-计算机学院-软件工程社区-CSDN社区云这个作业要求在哪里团队作业—beta冲刺事后诸葛亮-CSDN社区这个作业的目标记录beta冲刺Day7团队名称熬夜会秃头团队置顶集合随笔链接熬夜会秃头——Beta冲刺置顶随笔-CSDN社区 一、团队成员会议总结 1、成员工作…

蓝桥杯算法心得——小郑躲太阳(思维推导)

大家好&#xff0c;我是晴天学长&#xff0c;一道与平时的题型截然不同的题型&#xff0c;需要的小伙伴可以关注支持一下哦&#xff01;后续会继续更新的。&#x1f4aa;&#x1f4aa;&#x1f4aa; 1) .小郑躲太阳 问题描述 小郑一觉醒来发现起晚啦!现在需要从家里飞速前往公司…

服装行业中小企业零售数字化转型的工作目标和主要实施路径|徐礼昭

目标1&#xff1a;实现“人、货、场”的在线化和经营数字化 实施路径&#xff1a;中小企业可以选择商派的微信小程序商城系统&#xff0c;结合导购助手小程序&#xff0c;实现业务在线化&#xff0c;导购在线化&#xff0c;通过微信公众号、企微社群和视频号&#xff0c;开展私…