哈希表实验报告.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
哈希表实验报告重点讲义

实习报告题目:设计一个哈希表,完成相应的建表和查表程序班级:1503013 姓名:李睿元 学号完成日期:2016.12.04需求分析 1. 假设人名为中国人名的汉语拼音形式; 2. 待填入哈希表的姓名共有30个,去平均查找长度的上限为2; 3. 哈希函数用除留余数法构造,用伪随机探测再散列法处理冲突; 4. 取读者周围较熟悉的30个人的姓名。概要设计 1. 抽象数据类型的定义:(1)人名数据表: typedef struct Node { char name[20]; int key; }Node,NodeList[MAX];(2)哈希表:typedef struct hashtable{char* name;int key;int conflict_time;}HashTable[hashlen];变量:#define P 61//随机数值 #define MAX 30//人数 #define hashlen 61//哈希表长 2. 主要函数的实现:(1)哈希函数:int Hash(int key)关键字获得:int GetKey(char str[]) 文件流中读取姓名:void GetName(NodeList L,int i,FILE* fp)哈希表的初始化:void InitialHashTable(HashTable ht)伪随机探测序列的生成:void CreatConfilctArray(int n[])(6)哈希表的生成:void CreatHashTable(HashTable ht,NodeList L,int* n)哈希表的查询:void SearchHashTable(HashTable ht,int* n,char get_name[])详细设计#include stdio.h#include stdlib.h#include string.h#define P 61//随机数值 #define MAX 30//人数 #define hashlen 61//哈希表长 typedef struct Node{char name[20];int key; }Node,NodeList[MAX];typedef struct hashtable{char* name;int key;int conflict_time;}HashTable[hashlen];int Hash(int key){return key%P; } int GetKey(char str[]){int t=0;char *s=str;while(*s){t += *s;s++; } return t; } void GetName(NodeList L,int i,FILE* fp){/*printf(请以拼音形式输入第%d个姓名:,i);scanf(%s,L[i].name);L[i].key=GetKey(L[i].name); */fscanf(fp,%s,L[i].name);L[i].key=GetKey(L[i].name);//printf(\n);}void InitialHashTable(HashTable ht){int n=0;while(nhashlen){ht[n].conflict_time=0;ht[n].name=NULL;ht[n].key=0;n++;}}void CreatConfilctArray(int n[]){//n=(int*)malloc(50*sizeof(int)); int i=0,j=0;while(i50){n[i]=rand()%(hashlen+1);for(;ji;j++){if(n[i]==n[j]){j=0;n[i]=rand()%(hashlen+1);continue;}}i++;}}void CreatHashTable(HashTable ht,NodeList L,int* n){//CreatConfilctArray(n);int i=0;int t;while(iMAX){t=Hash(L[i].key);if(ht[t].conflict_time==0){ht[t].name=L[i].name;ht[t].conflict_time++;ht[t].key=L[i].key;printf(姓名:%s key值:%d 表内存储位置:%d\n,L[i].name,L[i].key,t);}else{int m=0;int d=(t+n[m])%hashlen; while(ht[d].conflict_time!=0){ht[d].conflict_time++;

文档评论(0)

dajuhyy + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档