查找和排序算法的实现(实验七).doc
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《查找和排序算法的实现(实验七).doc》由会员分享,可在线阅读,更多相关《查找和排序算法的实现(实验七).doc(9页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、!-实验 七 查找和排序算法的实现 一 实验目的及要求(1) 学生在实验中体会各种查找和内部排序算法的基本思想、适用场合,理解开发高效算法的可能性和寻找、构造高效算法的方法。(2) 掌握运用查找和排序解决一些实际应用问题。二.实验内容:(1) 编程实现一种查找算法(如折半查找、二叉排序树的查找、哈希查找等),并计算相应的ASL。(2) 编程实现一种内部排序算法(如插入排序、快速排序等)。三.实验主要流程、基本操作或核心代码、算法片段(该部分如不够填写,请另加附页)(1) 编程实现一种查找算法(如折半查找、二叉排序树的查找、哈希查找等),并计算相应的ASL。 程序代码:折半查找:头文件:#def
2、ine EQ(a,b) (a)=(b)#define LT(a,b) (a)(b)#define maxlength 20typedef int ElemType;typedef structElemType key;ElemType other;card;/每条记录包含的数据项typedef structcard rmaxlength; int length;SSTable;/一张表中包含的记录容量void Create(SSTable &L);int Search(SSTable L,int elem);功能函数:#include1.h#includestdio.hvoid Create(
3、SSTable &L) printf(新的线性表已经创建,请确定元素个数(不超过20)n); scanf(%d,&L.length); printf(请按递增序列输入具体的相应个数的整数元素(空格隔开)n); for(int i=0;iL.length;i+) scanf(%d,&L.ri.key); int Search(SSTable L,int elem)if(L.rL.length-1.keyelem) printf(表中没有该元素(不在范围内)n); return 0;int low=0,high=L.length-1;int mid;while(low=high)mid=(low+
4、high)/2;if(EQ(L.rmid.key,elem)printf(该元素在第%d位n,mid+1); return 0;else if(LT(elem,L.rmid.key) high=mid-1;else low=mid+1;printf(表中没有该元素(不在范围内)n);return 0;主函数:#includestdio.h#include1.hint main() SSTable L; Create(L); printf(n); printf(此时的线性表元素:n); for(int a=0;aL.length;a+) printf(%d ,L.ra.key); printf(
5、n); printf(n); int elem; do printf(请输入要查找的元素(输入000表示结束程序)n); scanf(%d,&elem);if(elem!=000) Search(L,elem); while(elem!=000); return 0; 运行结果:(2)编程实现一种内部排序算法(如插入排序、快速排序等)。程序代码部分:直接插入排序头文件:#define maxlength 20/最大数据容量#define OK 1typedef int Status;typedef int Other;typedef int KeyType;typedef structKeyT
6、ype key; Other data;Red;typedef structRed rmaxlength+1;/加了个哨兵的位置 int length;/当前数据个数SqList;Status Init(SqList &L);Status Insertsort(SqList &L);功能函数:#includestdio.h#include1.hStatus Init(SqList &L) printf(新的线性表以创建,请确定元素个数(不超过20)n); scanf(%d,&L.length); printf(请输入具体的相应个数的整数元素(空格隔开)n); for(int i=1/*将哨兵的
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 查找 以及 排序 算法 实现 实验 试验
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内