折半查找及其改进算法与大数据结构课程设计Word文档格式.docx
- 文档编号:17049939
- 上传时间:2022-11-28
- 格式:DOCX
- 页数:11
- 大小:244.92KB
折半查找及其改进算法与大数据结构课程设计Word文档格式.docx
《折半查找及其改进算法与大数据结构课程设计Word文档格式.docx》由会员分享,可在线阅读,更多相关《折半查找及其改进算法与大数据结构课程设计Word文档格式.docx(11页珍藏版)》请在冰豆网上搜索。
1、voidread_dat(SSTable*ST,intn),读取文件in.dat中的数据并建立一个含文件in.dat中前n个数据的静态查找表ST。
2、voidDestroyList(SSTable*ST),销毁表ST。
3、intSearchB1(SSTableST,KeyTypekey),利用折半查找的非递归算法,查找关键字等于key的数据元素,若存在,返回该元素在表中的位置,否则为0。
4、SearchB2(SSTableST,intkey,intlow,inthigh),利用折半查找的递归算法,查找关键字等于key的数据元素,若存在,返回该元素在表中的位置,否则为0。
5、SearchB3(SSTableST,KeyTypekey),对折半查找算法的一种改进
6、SearchB4(SSTableST,KeyTypekey),利用三分查找法,查找关键字等于key的数据元素,若存在,返回该元素在表中的位置,否则为0。
7、voidMainMenue(),主菜单。
8、main(),主函数。
六、数据结构
查找表类型定义如下:
typedefintKeyType;
typedefstruct
{KeyTypekey;
/*其它域:
略*/
}ElemType;
{ElemType*elem;
intlength;
}SSTable;
七、源程序
/*查找*/
#include"
stdio.h"
stdlib.h"
#defineEQ(a,b)((a)==(b))
#defineLT(a,b)((a)<
(b))
#defineLQ(a,b)((a)<
=(b))
/*查找表类型定义*/
/*1.读取文件数据并建立查找表*/
voidread_dat(SSTable*ST,intn)
{inti;
FILE*fp;
ST->
elem=(ElemType*)malloc((n+1)*sizeof(ElemType));
length=n;
fp=fopen("
in.txt"
"
r"
);
for(i=0;
i<
=n;
i++)
fscanf(fp,"
%d,"
&
ST->
elem[i].key);
printf("
SSTable:
(%d)\t"
ST->
elem[0].key);
for(i=1;
%5d"
fclose(fp);
}
/*2.销毁查找表*/
voidDestroyList(SSTable*ST)
{free(ST->
elem);
}
voidDestroy(SSTable*ST)
{if(ST->
elem)
ST->
length=0;
/*3.折半查找的非递归算法*/
intSearchB1(SSTableST,KeyTypekey)
{intlow,high,mid;
low=1;
high=ST.length;
while(low<
=high)
{mid=(low+high)/2;
if(EQ(key,ST.elem[mid].key))
returnmid;
elseif(LT(key,ST.elem[mid].key))
high=mid-1;
elselow=mid+1;
return0;
/*4.折半查找的递归算法*/
intSearchB2(SSTableST,intkey,intlow,inthigh)
{intmid;
if(low>
high)return0;
mid=(low+high)/2;
if(EQ(key,ST.elem[mid].key))
returnmid;
elseif(LT(key,ST.elem[mid].key))
returnSearchB2(ST,key,low,mid-1);
else
returnSearchB2(ST,key,mid+1,high);
}
/*5.对折半查找算法的一种改进*/
intMAX(SSTableST)
{intmax,i;
max=ST.elem[2].key-ST.elem[1].key;
for(i=2;
i<
ST.length-1;
i++)
if(max<
ST.elem[i+1].key-ST.elem[i].key)
max=ST.elem[i+1].key-ST.elem[i].key;
returnmax;
intSearchB3(SSTableST,KeyTypekey)
{intlow,high,mid,l=0,h=0,m=MAX(ST);
=high&
&
l>
=0&
h>
=0)
{l=(key-ST.elem[low].key)/m;
h=(ST.elem[high].key-key)/m;
mid=(low+high)/2;
if(EQ(key,ST.elem[mid].key))returnmid;
elseif(LT(key,ST.elem[mid].key))high=mid-1;
/*6.三分查找*/
intSearchB4(SSTableST,KeyTypekey)
{intmid1,mid2,low=1,high=ST.length;
if(ST.elem[low].key>
key||ST.elem[high].key<
key)return0;
{mid1=(high+low)/3;
mid2=(2*high+low)/3;
if(EQ(key,ST.elem[mid1].key))returnmid1;
elseif(LT(key,ST.elem[mid1].key))
high=mid1-1;
else
{if(EQ(key,ST.elem[mid2].key))returnmid2;
elseif(LT(key,ST.elem[mid2].key)){low=mid1+1;
high=mid2-1;
elselow=mid2+1;
return0;
/*7.主菜单*/
voidMainMenue()
{
printf("
\n**********************MainMenue***********************\n"
**1.折半查找的非递归算法**\n"
**2.折半查找的递归算法**\n"
**3.对折半查找算法的一种改进**\n"
**4.三分查找**\n"
**5.Exit.**\n"
********************************************************\n"
/*主函数*/
main()
{SSTableT;
KeyTypex;
intn,flag=1;
charc;
printf("
\n请输入表长:
"
scanf("
%d"
&
n);
read_dat(&
T,n);
MainMenue();
while(flag)
{printf("
\nPleaseinputyourchoice:
"
scanf("
%s"
c);
switch(c)
{
case'
1'
:
\n折半查找的非递归算法:
)
\n请输入待查元素:
scanf("
x);
\n元素%d在表中的位置:
x,SearchB1(T,x));
break;
2'
\n折半查找的递归算法:
x,SearchB2(T,x,1,T.length);
3'
\n对折半查找算法的一种改进:
x,SearchB3(T,x));
4'
\n三分查找:
printf("
scanf("
x,SearchB4(T,x));
break;
5'
exit
(1);
default:
Inputerror!
\n"
}
Destroy(&
T);
八、测试情况
测试结果:
输出文件中前50位数和主菜单,运行正确。
查找58在表中位置,因为58不在表中,所以输出0,程序运行结果
正确。
元素18在表中位置为18,结果正确
输出文件中前100位数和主菜单,运行正确。
元素18在表中位置为18,运行结果正确。
元素58在表中位置为58,运行结果正确。
九、参考文献
1、严蔚敏,《数据结构C语言》,清华大学出版社。
2、谭浩强,《c语言程序设计》,清华大学出版社。
小结
通过本次课程设计,我学到了很多。
它让我真正的理解了什么是程序,程序=算法+结构。
编程的第一要务是把事物分析清楚,把事件先后的逻辑关系和依赖关系搞清楚,从而确定相应的数据结构,然后写代码去实现。
所以只有学好数据结构,才能编好程序。
编程不像做其它事,它要求编程人员有非常缜密的思维,很好的整体把握能力和很好的调试程序的能力等。
决定程序成功与否的往往不是程序的整体思路和整体算法,而是细节,细节错误往往是程序失败的终级杀手,我在此次课程设计中深有体会。
如不同输入法下的分号不同,有个分号我是在中文输入法下输入的,导致我的程序运行的结果出错,花了我一定时间才检查出来错误。
同时我也认识到编译工具的重要性,我用的是VC++6.0环境,提高我编写程序的效率,如按回车后,它能自动空出一定距离,体现出程序的结构,不用人工输入空格、制表符,还有它的调试功能,不用我人工输出中间变量来查错,就能看到中间变量。
在实验编写程序的过程中,遇到了很多的问题,这些在我以前的实验中都是没遇到的,比如三分查找,在给出n个已经排好序的数,在n/3和2n/3处各取一个数,跟给定值key比较,由于比较时会出现很多的情况,每一种情况都需要仔细考虑到,在编程中,因为没有认真分析,考虑不周全,导致一些情况遗漏了,程序出现了错误,经过后来认真分析,最终找到了遗漏的情况,程序运行成功。
还有在编写基于区间约束对折半查找算法的改进算法的设计过程中,也遇到了类似的错误,考虑条件不周全,程序无法运行,后改正。
可见编程过程中一定要认真分析各种条件,考虑周全,细节决定成败。
通过这次课程设计,我领略到分工合作精神,集体编程和个人编程有很大不同,相互间独立而又紧密联系在一起,如编写三分查找时,我是独立编写,但是我要知道相应的存储结构,进而完成编写。
编程过程中要能体现创新精神,在编写读取文件数据函数的程序中,由于读取的数据需要相应的存储结构存取,所以我将建立查找表的程序加在文件数据函数的程序中,即将读取的数据直接建立一个查找表,避免了另外编写建立查找表的繁琐,自认为不失为一种创新。
这次课程设计还让懂得如何利用以前所学的知识,例如,在验证实验结果时,为了能更好验证实验准确性,我想到了以前其他实验中采取的控制变量法,使实验结果正确性更具说服力。
经过这次课程设计,我学到了很多东西,不仅巩固和加深了对数据结构的理解,提高综合运用本课程所学知识的能力,而且培养了我选用参考书,查阅手册及文献资料的能力,培养独立思考,深入研究,分析问题、解决问题的能力。
课程设计是把我们所学的理论知识进行系统的总结并应用于实践的良好机会,有利于加强我们用知识理论来分析实际问题的能力,进而加强了我们对知识认识的实践度,巩固了我们的理论知识,深化了对知识的认识,并为走向社会打下一个良好的基础。
在这次课程设计中我遇到许多问题和麻烦,得到了老师的帮助和指导,才能够使得这次课程设计顺利的进行下去,另外,在程序调试过程中,也得到很多同学的帮助,给我及时指出错误,提出许多宝贵意见。
在此对老师和同学们表示感谢!
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 折半 查找 及其 改进 算法 数据结构 课程设计