- 1、本文档共3页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
《数据结构》查找 实验报告格式
河南工业大学实验报告
课程 数据结构 _ 实验名称 实验五: 查找
院 系___________________ 专业班级__ ____ 实验地点
姓 名__________ 学 号____________ 实验时间
指导老师 王云侠 实验成绩 批改日期
实验目的
熟悉静态查找的相关算法
实验内容及要求
实现顺序表的查找算法
实现有序表的折半查找算法
实验过程及结果
实验过程:
源程序:
顺序查找:
#include stdio.h
#define MAX_SIZE 100
typedef struct{
int key;
}element;
element list[MAX_SIZE];
int seqsearch(element list[],int searchnum,int num);
int main()
{
int i,num,searchnum,k;
printf(请输入元素的个数:);
scanf(%d,num);
printf(请输入元素:\n);
for(i=0;inum;i++)
{
scanf(%d,list[i].key);
}
while(1)
{
printf(请输入要查询的数据元素:);
scanf(%d,searchnum);
k=seqsearch(list,searchnum,num);
if(k!=-1)
{
printf(所查询元素的下标为:);
printf(%d\n,k);
}
else
printf(查询元素不存在。\n);
}
return 0;
}
int seqsearch(element list[],int searchnum,int num)
{
int j;
list[num].key=searchnum;
for(j=0;list[j].key!=searchnum;j++)
;
return jnum?j:-1;
}
折半查找:
#include stdio.h
#define MAX_SIZE 100
#define COMPARE(a,b) (a)(b)?1:(a)==(b)?0:-1
typedef struct{
int key;
}element;
element list[MAX_SIZE];
int binsearch(element list[],int searchnum,int num);
int main()
{
int i,num,searchnum,k;
printf(请输入元素的个数:);
scanf(%d,num);
printf(请输入元素:\n);
for(i=0;inum;i++)
{
scanf(%d,list[i].key);
}
while(1)
{
printf(请输入要查询的数据元素:);
scanf(%d,searchnum);
k=binsearch(list,searchnum,num);
if(k!=-1)
{
printf(所查询元素的下标为:);
printf(%d\n,k);
}
else
printf(查询元素不存在。\n);
}
return 0;
}
int binsearch(element list[],int searchnum,int num)
{
int left=0,right=num-1,middle;
while(left=right)
{
middle=(left+right)/2;
switch(COMPARE(list[middle].key,searchnum))
{
case 1:right=middle-1;break;
case 0:return middle;
case -1:left=middle+1;
}
}
return -1;
}
实验结果:
实验中的问题及心得
通过上机练习,我收获了很多,尤其是老师的耐心讲解让我受益颇深。经过这次实验,加深了我对查找表的认识。但是,实验中也出现了问题,首先程序循环不能良好退出,操作时经常出错。相信经过以后的学习我能解决这些问题。
您可能关注的文档
- Touch Window 结构篇分析.pdf
- Toward the Scientific Evaluation of Music Information Retrieval Systems.pdf
- Towards a Better Forecasting Model for Economic Indices.pdf
- Torture Tests A Quantitative Analysis for the Robustness of KnowledgeBased Systems.pdf
- Towards a Standardization of ObjectOriented Modelling Languages (Working Paper No.pdf
- Towards a Temporal Extension of Formal Concept Analysis.pdf
- Towards a Tool for Performance Evaluation of Autonomous Vehicle Navigation in Dynamic, OnR.pdf
- Towards Better Integrators for Dissipative Particle Dynamics Simulations.pdf
- Towards Information Retrieval Measures for Evaluation of Web Search Engines. Unpublished ma.pdf
- Towards an Effectivisation of the Riemann Theorem.pdf
文档评论(0)