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

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 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 ");

相关文档
最新文档