- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
查找与排序实验.doc
附件(四)
深圳大学实验报告
课程名称:
实验项目名称:
学院:
专业:
指导教师2
报告人:
实验时间:
实验报告提交时间:
:据结构实验与课程设计
树结构实验
计算机与软件学院
软件工程
班级:
教务处制
一、实验目的与完成说明:
数裾结构实验--哈希査找
给出一个数裾序列,建立哈希表,采用求余法作为哈希函数,模数为11,哈希冲突用链 地址法和表头插入
如果首次查找失败,就把数据插入到相应的位置屮
实现哈希查找功能
数据结构实验--希尔排序
给出一个数据序列,使用希尔排序算法进行从小到大的排序
间隔gap使用序列长度循环除2直到1
数据结构实验--快速排序
第一行输入t,表示有t个测试示例 第二行输入n,表示第一个示例有n个数据 第三行输入n个数据,都是正整数,数据之间用空格隔开 以此类推
二、主要思路与方法:
哈希査找:
给定K值,根据造表时设定的哈希函数得到哈希地址,若此表中此位置没有记录,则査 找不成功,否则比较关键字,若何给定值相等,则查找成功;否则根据造表时设定的处 理冲突的方法找下一地址,直至哈希表的某个位置为空或表中记录的关键字等于给定的 定值时为止。
希尔排序:
先将整个待排记录序列分割成若干子序列分别进行直接插入排序,待整个序列中的记录 基本有序时,再对全体记录进行一次直接插入排序。
快速排序:
通过一趟排序将待排记录分割成独立的两个部分,其中一部分记录的关键字均比另一部 分记录的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序。
实验程序或内容:
哈希査找:
#includeiostream using namespace std;
class node{ public:
int data; node氺 next;
nodc(){data=0;ncxt=NULL;}
};
int main()
{
int n;
bool visit[11]; for (int z二0;z〈ll;z++)
visit [z]=false;
int i; cinn; int a[20]; for (i=0;in;i++)
cin〉〉a[i];
int target, temp; node mylistnode[ll]; for(i=0;in;i++){
temp=a[i]%l1; if(!visit[temp])
{
node* s=new node (); s-data二a[i]; mylistnode[temp]. next=s; visit [temp]=true;
}
else
{
node* p=mylistnode[temp]. next; node* q=new node (); q-data=a[i]; mylistnode[temp]. next=q; q-next=p;
}
}
int t; cin?t; while(t—)
{
cintarget;
int tl=target%ll; if (! visit [tl])
cout〈〈〃error〃〈〈endl; node本 r=ncw nodc(); r-〉data=target; niylistnode[tl]. next=r; visit[tl]=true;
}
else
{
int flag=0; int count=0;
node氺 x=mylistnode[tl] next; while (x!=NULL)
{
count++;
if (x~data==target)
{
flag=l;
break;
}
x=x-next;
}
if(flag==0)
{
node氺 n2=mylistnode[tl].next; node* newnode=new node (); newnode-data=target; mylistnodc[tl]e ncxt=ncwnodc; newnode-next=n2; cout?/zerrorzz?endl;
}
else
{
cout〈〈tl〈〈 cout?count?endl;
return 0;希尔排序:
return 0;
希尔排序:
#includeiostream using namespace std;
class haxi {
public:
void Shelllnsert(int list口,int dk, int length) { int i, j;
for (i=dk+l;i=lcngth;++i)
if (list[i]list[i~dk]){ list [0]=list[i]; for(j=i-dk;j0
(list[O]list[j]);j-=dk)
list[j+dk]=list[j]; list [j+dk]=list[0];
void Shell
您可能关注的文档
最近下载
- 《红楼梦》中的文化娱乐与艺术表达.pptx VIP
- TZHYL-智慧医院医用耗材 SPD 供应链风险控制指南.pdf VIP
- 数据挖掘知到课后答案智慧树章节测试答案2025年春中国人民解放军国防科技大学.docx VIP
- VDA6.3潜在供方审核P1.xlsx VIP
- 电力公司线路工程资料移交清单 .pdf VIP
- 黑龙江 2023年兽医实验室考试:兽医实验室技术理论真题模拟汇编(共285题).doc VIP
- 2025至2030年中国商务服务市场调查研究及行业投资潜力预测报告.docx
- 第10课 相互了解 相互尊重 教案 人民版中华民族大家庭.pdf VIP
- 2025年七年级数学(上)第1单元《有理数易错题练习》及答案 .pdf VIP
- GB_T 20394-2019 体育用人造草.docx VIP
文档评论(0)