ImageVerifierCode 换一换
格式:DOCX , 页数:21 ,大小:40.97KB ,
资源ID:2888594      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/2888594.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据结构课程设计哈希表实验报告.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

数据结构课程设计哈希表实验报告.docx

1、数据结构课程设计哈希表实验报告福 建 工 程 学 院课 程 设 计课程: 算法与数据结构 题目: 哈希表 专业: 网络工程 班级: xxxxxx班 座号: xxxxxxxxxxxx 姓名: xxxxxxx 2011年 12 月 31 日实验题目:哈希表一、 要解决的问题 针对同班同学信息设计一个通讯录,学生信息有姓名,学号,电话号码等。以学生姓名为关键字设计哈希表,并完成相应的建表和查表程序。 基本要求:姓名以汉语拼音形式,待填入哈希表的人名约30个,自行设计哈希函数,用线性探测再散列法或链地址法处理冲突;在查找的过程中给出比较的次数。完成按姓名查询的操作。 运行的环境:Microsoft V

2、isual C+ 6.0二、算法基本思想描述 设计一个哈希表(哈希表内的元素为自定义的结构体)用来存放待填入的30个人名,人名为中国姓名的汉语拼音形式,用除留余数法构造哈希函数,用线性探查法解决哈希冲突。建立哈希表并且将其显示出来。通过要查找的关键字用哈希函数计算出相应的地址来查找人名。通过循环语句调用数组中保存的数据来显示哈希表。三、设计1、数据结构的设计和说明(1)结构体的定义 typedef struct /记录 NA name; NA xuehao; NA tel;Record;录入信息结构体的定义,包含姓名,学号,电话号码。typedef struct /哈希表 Record *el

3、emHASHSIZE; /数据元素存储基址 int count; /当前数据元素个数 int size; /当前容量HashTable;哈希表元素的定义,包含数据元素存储基址、数据元素个数、当前容量。2、关键算法的设计 (1)姓名的折叠处理 long fold(NA s) /人名的折叠处理 char *p; long sum=0; NA ss; strcpy(ss,s); /复制字符串,不改变原字符串的大小写 strupr(ss); /将字符串ss转换为大写形式 p=ss; while(*p!=0) sum+=*p+; printf(nsum=%d,sum); return sum;(2)建立

4、哈希表 1、用除留余数法构建哈希函数 2、用线性探测再散列法处理冲突 int Hash1(NA str) /哈希函数 long n; int m; n=fold(str); /先将用户名进行折叠处理 m=n%HASHSIZE; /折叠处理后的数,用除留余数法构造哈希函数 return m; /并返回模值Status collision(int p,int c) /冲突处理函数,采用二次探测再散列法解决冲突 int i,q; i=c/2+1; while(i=0) return q; else i=c/2+1; else q=(p-i*i)%HASHSIZE; c+; if(q=0) retur

5、n q; else i=c/2+1; return UNSUCCESS;void benGetTime();void CreateHash1(HashTable* H,Record* a) /建表,以人的姓名为关键字,建立相应的散列表 int i,p=-1,c,pp; system(cls); /若哈希地址冲突,进行冲突处理 benGetTime(); for(i=0;ielempp!=NULL) pp=collision(p,c); if(ppelempp=&(ai); /求得哈希地址,将信息存入 H-count+; printf(第%d个记录冲突次数为%d。n,i+1,c); /需要显示冲

6、突次数时输出 printf(n建表完成!n此哈希表容量为%d,当前表内存储的记录个数为%d.n,HASHSIZE,H-count); benGetTime();(3)查找哈希表 void SearchHash1(HashTable* H,int c) /在通讯录里查找姓名关键字,若查找成功,显示信息int p,pp;NA str; system(cls); /c用来记录冲突次数,查找成功时显示冲突次数 benGetTime(); printf(n请输入要查找记录的姓名:n); scanf(%s,str); p=Hash1(str); pp=p; while(H-elempp!=NULL)&(e

7、q(str,H-elempp-name)=-1) pp=collision(p,c); if(H-elempp!=NULL&eq(str,H-elempp-name)=1) printf(n查找成功!n查找过程冲突次数为%d以下是您需要要查找的信息:nn,c); printf(姓 名:%sn学号:%sn电话号码:%sn,H-elempp-name,H-elempp-xuehao,H-elempp-tel); else printf(n此人不存在,查找不成功!n); benGetTime();(4)显示哈希表 void ShowInformation(Record* a) /显示输入的用户信息i

8、nt i; system(cls); for( i=0;iNUM_BER;i+) printf(n第%d个用户信息:n 姓 名:%sn 学号:%sn 电话号码:%sn,i+1,ai.name,ai.xuehao,ai.tel);(5)主函数的设计void main(int argc, char* argv)Record aMAXSIZE; int c,flag=1,i=0; HashTable *H; H=(HashTable*)malloc(LEN); for(i=0;ielemi=NULL; H-size=HASHSIZE; H-count=0; while (1) int num; pr

9、intf(n ); printf(n 欢迎使用同学通讯录录入查找系统 ); printf(n 哈希表的设计与实现); printf(n 【1】. 添加用户信息 ); printf(n 【2】. 读取所有用户信息 ); printf(n 【3】. 以姓名建立哈希表(再哈希法解决冲突) ); printf(n 【4】. 以电话号码建立哈希表(再哈希法解决冲突) ); printf(n 【5】. 查找并显示给定用户名的记录 ); printf(n 【6】. 查找并显示给定电话号码的记录 ); printf(n 【7】. 清屏 ); printf(n 【8】. 保存 ); printf(n 【9】.

10、退出程序 ); printf(n 温馨提示: ); printf(n .进行5操作前 请先输出3 ); printf(n .进行6操作前 请先输出4 ); printf(n); printf(请输入一个任务选项); printf(n); scanf(%d,&num); switch(num) case 1: getin(a); break; case 2: ShowInformation(a); break; case 3: CreateHash1(H,a); /* 以姓名建立哈希表 */ break; case 4: CreateHash2(H,a); /* 以电话号码建立哈希表 */ br

11、eak; case 5: c=0; SearchHash1(H,c); break; case 6: c=0; SearchHash2(H,c); break; case 7: Cls(a); break; case 8: Save(); break; case 9: return 0; break; default: printf(你输错了,请重新输入!); printf(n); system(pause); return 0;3、模块结构图及各模块的功能: 四、源程序清单: #include#include#include#include #define MAXSIZE 20 #defin

12、e MAX_SIZE 20 #define HASHSIZE 53 #define SUCCESS 1#define UNSUCCESS -1#define LEN sizeof(HashTable)typedef int Status;typedef char NAMAX_SIZE;typedef struct NA name; NA xuehao; NA tel;Record;typedef struct Record *elemHASHSIZE; int count; int size; HashTable;Status eq(NA x,NA y) if(strcmp(x,y)=0) r

13、eturn SUCCESS; else return UNSUCCESS;Status NUM_BER; void getin(Record* a) int i; system(cls); printf(输入要添加的个数:n); scanf(%d,&NUM_BER); for(i=0;iNUM_BER;i+) printf(请输入第%d个记录的姓名:n,i+1); scanf(%s,ai.name); printf(请输入%d个记录的学号:n,i+1); scanf(%s,ai.xuehao); printf(请输入第%d个记录的电话号码:n,i+1); scanf(%s,ai.tel); void

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1