数据结构-实验三-排序查找的应用

数据结构-实验三-排序查找的应用

ID:42609951

大小:124.12 KB

页数:5页

时间:2019-09-18

数据结构-实验三-排序查找的应用_第1页
数据结构-实验三-排序查找的应用_第2页
数据结构-实验三-排序查找的应用_第3页
数据结构-实验三-排序查找的应用_第4页
数据结构-实验三-排序查找的应用_第5页
资源描述:

《数据结构-实验三-排序查找的应用》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、数据结构实验报告实验三:排序查找的应用姓名:周成学号:13083511专业:软件工程任课教师:马慧珠2013年12月01日1.实验名称:排序查找的应用2.实验目的:学会如何应用排序算法和查找算法实现排序、查找3.实验要求:先从键盘上输入26个字母生成无序数组,对数组进行排序,再从键盘输入一个字符进行查找。4.实验内容:利用冒泡排序和折半查找的方法找到需要找的字符。折半插入排序(binaryinsertionsort)是对插入排序算法的一种改进,由于排序算法过程中,就是不断的依次将元素插入前面已排好序的序列中。由于前半部分为已排好序的数列,

2、这样我们不用按顺序依次寻找插入点,可以采用折半查找的方法来加快寻找插入点的速度。折半插入排序算法的具体操作为:在将一个新元素插入已排好序的数组的过程中,寻找插入点时,将待插入区域的首元素设置为a[low],末元素设置为a[high],则轮比较时将待插入元素与a[m],其中m=(low+high)/2相比较,如果比参考元素小,则选择a[low]到a[m-1]为新的插入区域(即high=m-1),否则选择a[m+1]到a[high]为新的插入区域(即low=m+1),如此直至low<=high不成立,即将此位置之后所有元素后移一位,并将新元素

3、插入a[high+1]。5.实验程序代码及运行结果://数ºy据Y结¨¢构1_实º¦Ì验¨¦三¨y_排?序¨°查¨¦找¨°的Ì?应®

4、用®?.cpp:定¡§义°?控?制?台¬¡§应®

5、用®?程¨¬序¨°的Ì?入¨?口¨²点Ì?。¡ê//#include"stdafx.h"#include#include#defineMAX50typedefcharDataType;typedefstruct//定¡§义°?结¨¢构1体¬?SequeList{DataTypedata[MAX];intlength;}S

6、equeList;SequeList*Initist(SequeList*L)//顺3序¨°表À¨ª的Ì?初?始º?化¡¥{L=(SequeList*)malloc(sizeof(SequeList));L->length=-1;returnL;}SequeList*BubbleSort(SequeList*L)//冒¡ã泡Y排?序¨°{inti,j;DataTypetemp;for(i=0;ilength;i++)for(j=i+1;jlength;j++)if(L->data[i]>L->data[j]){temp=L

7、->data[i];L->data[i]=L->data[j];L->data[j]=temp;}returnL;}intBinSearch(SequeList*L,DataTypek)//折?半ã?查¨¦找¨°{intlow=0,high=L->length-1,mid;while(low<=high){mid=(low+high)/2;if(L->data[mid]==k)returnmid;elseif(L->data[mid]>k)high=mid-1;elselow=mid+1;}return-1;}voidPrintList(

8、SequeList*L)//打䨰印®?输º?出?元a素?{inti;for(i=0;ilength;i++)printf("%c",L->data[i]);printf("");}intmain(){inti,t,j=0;DataTypecc;SequeList*L;L=(SequeList*)malloc(sizeof(SequeList));L=Initist(L);printf("请?输º?入¨?26个?字Á?符¤?:êo");L->length=26;for(i=0;i<27;i++)scanf("%c",&L

9、->data[i]);L=BubbleSort(L);printf("此ä?组Á¨¦数ºy排?完ª¨º序¨°后¨®为a:êo");PrintList(L);printf("请?输º?入¨?要°a查¨¦找¨°的Ì?字Á?符¤?:êo");scanf("%c",&cc);t=BinSearch(L,cc)+1;if(t==0)printf("此ä?顺3序¨°表À¨ª中D没?有®D该?字Á?符¤?!");elseprintf("此ä?字Á?符¤?在¨²顺3序¨°表À¨ª中D的Ì?第̨²%d个?位?置?。¡ê",t);retur

10、n0;}程序截图:6.实验总结冒泡排序是排序算法中比较经典的一个,很方便,而且算法很成熟。这般排序折半插入排序算法是一种稳定的排序算法,比直接插入算法明显减少了关键字之间比较的次数,因此速度比

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。