数据结构课程设计--哈希表实验报告
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
福建工程学院课程设计
课程:算法与数据结构
题目:哈希表
专业:网络工程
班级:xxxxxx班
座号:xxxxxxxxxxxx
姓名:xxxxxxx
2011年12 月31 日
实验题目:哈希表
一、要解决的问题
针对同班同学信息设计一个通讯录,学生信息有姓名,学号,电话号码等。以学生姓名为关键字设计哈希表,并完成相应的建表和查表程序。
基本要求:姓名以汉语拼音形式,待填入哈希表的人名约30个,自行设计哈希函数,用线性探测再散列法或链地址法处理冲突;在查找的过程中给出比较的次数。完成按姓名查询的操作。
运行的环境:Microsoft Visual C++ 6.0
二、算法基本思想描述
设计一个哈希表(哈希表内的元素为自定义的结构体)用来存放待填入的30个人名,人名为中国姓名的汉语拼音形式,用除留余数法构造哈希函数,用线性探查法解决哈希冲突。建立哈希表并且将其显示出来。通过要查找的关键字用哈希函数计算出相应的地址来查找人名。通过循环语句调用数组中保存的数据来显示哈希表。
三、设计
1、数据结构的设计和说明
(1)结构体的定义
typedef struct //记录
{
NA name;
NA xuehao;
NA tel;
}Record;
录入信息结构体的定义,包含姓名,学号,电话号码。
typedef struct //哈希表
{
Record *elem[HASHSIZE]; //数据元素存储基址
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)建立哈希表
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 if(c%2==0){ c++; q=(p+i*i)%HASHSIZE; if(q>=0) return q; else i=c/2+1; } else{ q=(p-i*i)%HASHSIZE; c++; if(q>=0) return q; else i=c/2+1; } } return UNSUCCESS; } void benGetTime(); } else printf("\n此人不存在,查找不成功!\n"); benGetTime(); } (4)显示哈希表 void ShowInformation(Record* a) //显示输入的用户信息 {int i; system("cls"); for( i=0;i printf("\n第%d个用户信息:\n 姓名:%s\n 学号:%s\n 电话号码:%s\n",i+1,a[i].name,a[i].xuehao,a[i].tel); } (5)主函数的设计 void main(int argc, char* argv[]) {Record a[MAXSIZE]; int c,flag=1,i=0; HashTable *H; H=(HashTable*)malloc(LEN); for(i=0;i H->elem[i]=NULL; H->size=HASHSIZE; H->count=0; } while (1) { int num; printf("\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】. 退出程序"); printf("\n 温馨提示:"); printf("\n Ⅰ.进行5操作前请先输出3 "); printf("\n Ⅱ.进行6操作前请先输出4 ");