写在前面:博主是一位普普通通的19届双非软工在读生,平时最大的爱好就是听听歌,逛逛B站。博主很喜欢的一句话
花开堪折直须折,莫待无花空折枝
:博主的理解是头一次为人,就应该做自己想做的事,做自己不后悔的事,做自己以后不会留有遗憾的事,做自己觉得有意义的事,不浪费这大好的青春年华。博主写博客目的是记录所学到的知识并方便自己复习,在记录知识的同时获得部分浏览量,得到更多人的认可,满足小小的成就感,同时在写博客的途中结交更多志同道合的朋友,让自己在技术的路上并不孤单。
目录:
1.分块查找简介
2.分块查找具体实现
3.分块查找代码(C语言完整代码)
1.分块查找简介
分块查找,也叫索引顺序查找,算法实现除了需要查找表本身之外,还需要根据查找表建立一个索引表。
例如下图,给定一个查找表,其对应的索引表如图所示:
查找表中共 18 个查找关键字,将其平均分为 3 个子表,对每个子表建立一个索引,索引中包含中两部分内容:该 子表部分中最大的关键字 以及 第一个关键字在总表中的位置,即该子表的起始位置
建立的索引表要求按照关键字进行升序排序,查找表要么整体有序,要么分块有序。 分块有序指的是第二个子表中所有关键字都要大于第一个子表中的最大关键字,第三个子表的所有关键字都要大于第二个子表中 的最大关键字,依次类推。
块(子表)中各关键字的具体顺序,根据各自可能会被查找到的概率而定。如果各关键字被查找到的概率是相等的,那么可以随 机存放;否则可按照被查找概率进行降序排序,以提高算法运行效率。
2.分块查找具体实现
所有前期准备工作完成后,开始在此基础上进行分块查找。分块查找的过程分为两步进行:
- 确定要查找的关键字可能存在的具体块(子表);
- 在具体的块中进行顺序查找。
以上图中的查找表为例,假设要查找关键字 38 的具体位置。首先将 38 依次和索引表中各最大关键字进行比较,因为 22 < 38 < 48,所以可以确定 38 如果存在,肯定在第二个子表中。 由于索引表中显示第二子表的起始位置在查找表的第 7 的位置上,所以从该位置开始进行顺序查找,一直查找到该子表最后一 个关键字(一般将查找表进行等分,具体子表个数根据实际情况而定)。结果在第 10 的位置上确定该关键字即为所找
3.分块查找代码(C语言完整代码)
#include <stdio.h>
#include <stdlib.h>
struct index {
//定义块的结构
int key;
int start;
} newIndex[3]; //定义结构体数组
int search(int key, int a[