您所在位置: 网站首页 / 文档列表 / 实验设计 / 文档详情
哈希表实验报告2.doc 立即下载
上传人:天马****23 上传时间:2024-09-09 格式:DOC 页数:63 大小:2.3MB 金币:10 举报 版权申诉
预览加载中,请您耐心等待几秒...

哈希表实验报告2.doc

哈希表实验报告2.doc

预览

免费试读已结束,剩余 53 页请下载文档后查看

10 金币

下载文档

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

哈希表实验报告2优质资料(可以直接使用,可编辑优质资料,欢迎下载)实习报告题目:设计一个哈希表,完成相应的建表和查表程序班级:1503013姓名:李睿元学号:15030130073完成日期:2021.12.04需求分析1.假设人名为中国人名的汉语拼音形式;2.待填入哈希表的姓名共有30个,去平均查找长度的上限为2;3.哈希函数用除留余数法构造,用伪随机探测再散列法处理冲突;4.取读者周围较熟悉的30个人的姓名。概要设计1.抽象数据类型的定义:(1)人名数据表:typedefstructNode{charname[20];intkey;}Node,NodeList[MAX];(2)哈希表:typedefstructhashtable{char*name;intkey;intconflict_time;}HashTable[hashlen];变量:#defineP61//随机数值#defineMAX30//人数#definehashlen61//哈希表长2.主要函数的实现:(1)哈希函数:intHash(intkey)关键字获得:intGetKey(charstr[])文件流中读取姓名:voidGetName(NodeList&L,inti,FILE*fp)哈希表的初始化:voidInitialHashTable(HashTable&ht)伪随机探测序列的生成:voidCreatConfilctArray(intn[])(6)哈希表的生成:voidCreatHashTable(HashTable&ht,NodeListL,int*n)哈希表的查询:voidSearchHashTable(HashTableht,int*n,charget_name[])详细设计#include<stdio.h>#include<stdlib.h>#include<string.h>#defineP61//随机数值#defineMAX30//人数#definehashlen61//哈希表长typedefstructNode{charname[20];intkey;}Node,NodeList[MAX];typedefstructhashtable{char*name;intkey;intconflict_time;}HashTable[hashlen];intHash(intkey){returnkey%P;}intGetKey(charstr[]){intt=0;char*s=str;while(*s){t+=*s;s++;}returnt;}voidGetName(NodeList&L,inti,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");}voidInitialHashTable(HashTable&ht){intn=0;while(n<hashlen){ht[n].conflict_time=0;ht[n].name=NULL;ht[n].key=0;n++;}}voidCreatConfilctArray(intn[]){//n=(int*)malloc(50*sizeof(int));inti=0,j=0;while(i<50){n[i]=rand()%(hashlen+1);for(;j<i;j++){if(n[i]==n[j]){j=0;n[i]=rand()%(hashlen+1);continue;}}i++;}}voidCreatHashTable(HashTable&ht,NodeListL,int*n){//CreatConfilctArray(n);inti=0;intt;while(i<MAX){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("姓名:%skey值:%d表内存储位置:%d\n",L[i].name,L[i].key,t);}else{intm=0;intd=(t+n[m])%ha
单篇购买
VIP会员(1亿+VIP文档免费下)

扫码即表示接受《下载须知》

哈希表实验报告2

文档大小:2.3MB

限时特价:扫码查看

• 请登录后再进行扫码购买
• 使用微信/支付宝扫码注册及付费下载,详阅 用户协议 隐私政策
• 如已在其他页面进行付款,请刷新当前页面重试
• 付费购买成功后,此文档可永久免费下载
年会员
99.0
¥199.0

6亿VIP文档任选,共次下载特权。

已优惠

微信/支付宝扫码完成支付,可开具发票

VIP尽享专属权益

VIP文档免费下载

赠送VIP文档免费下载次数

阅读免打扰

去除文档详情页间广告

专属身份标识

尊贵的VIP专属身份标识

高级客服

一对一高级客服服务

多端互通

电脑端/手机端权益通用

手机号注册 用户名注册
我已阅读并接受《用户协议》《隐私政策》
已有账号?立即登录
我已阅读并接受《用户协议》《隐私政策》
已有账号?立即登录
登录
手机号登录 微信扫码登录
微信扫一扫登录 账号密码登录

首次登录需关注“豆柴文库”公众号

新用户注册
VIP会员(1亿+VIP文档免费下)
年会员
99.0
¥199.0

6亿VIP文档任选,共次下载特权。

已优惠

微信/支付宝扫码完成支付,可开具发票

VIP尽享专属权益

VIP文档免费下载

赠送VIP文档免费下载次数

阅读免打扰

去除文档详情页间广告

专属身份标识

尊贵的VIP专属身份标识

高级客服

一对一高级客服服务

多端互通

电脑端/手机端权益通用