- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
叫我小老虎
0
一、需求分析
1、问题描述
为某个单位建立一个员工通讯录管理系统,可以方便查询每一个员工
的电话与地址。设计散列表存储,设计并实现通讯录查找系统。
2、基本要求
a.每个记录有下列数据项:电话号码、用户名、地址;
b.从键盘输入各记录,分别以电话号码为关键字建立散列表;
c.采用二次探测再散列法解决冲突;
d.查找并显示给定电话号码的记录;
e.通讯录信息文件保存。
二、概要设计
1.数据结构
本程序需要用到两个结构体,分别为通讯录 message 以及哈希表
HxList
2.程序模块
本程序包含两个模块,一个是实现功能的函数的模块,另一个是主函
数模块。
系统子程序及功能设计
本系统共有三个子程序,分别是:
int Hx(long long key,int data)// 哈希函数
void BulidHx(HxList L)//建立通讯录
1
int Search(HxList L)//查找
3. 各模块之间的调用关系以及算法设计
主函数调用BulidHx 以及Search 函数。
函数BulidHx 调用函数Hx。
三、详细设计
1.数据类型定义
typedef struct
{
char *name;
char *add;
long long phonenumber;
}message;
typedef struct
{
message *list;
int number;//记录数
}HxList;
2.系统主要子程序详细设计
a. 建立通讯录
void BulidHx(HxList L)//建立通讯录
{
FILE *f = fopen(E:\\tongxunlu.txt, w);
char buf[20]={0},str[20]={0};
long long key;
cout输入要建立的记录数:;
cinL.number;
L.number+=1;
L.list=new message[L.number];//分配哈希表的存储空间
for(int i=0;iL.number;i++)
{
L.list[i].phonenumber=-1;
}
L.list[L.number-1].name=NULL;
L.list[L.number-1].add=NULL;
2
cout输入记录信息( 电话号码 用户名 地址)endl;
for(int i=0;iL.number-1;i++)
{
cinkeybufstr;
int pose=Hx(key,L.number);//获取理论上的存储位置
if(L.list[pose].phonenumber==-1)
{
}
else
{
//用二次探测再散列法解决冲突
//1^2 -1^2 2^2 -2^2
int di,count=1;
xunhuan: if(count%2==0)
di=-(count/2)*(count/2);
else
di=((count/2)+1)*((count/2)+1);
int site=Hx(key+di,L.number);
if(site=0)
{
if(L.list[site].phonenumber==-1)
{
pose=site
您可能关注的文档
最近下载
- 2025年国家开放大学电大专科《办公室管理》简答题题库及答案.docx
- 除害服务灭蚊方案.doc VIP
- 数学竞赛数学分析讲义(泛函分析)-239页 文字版 好.pdf
- 商场消防控制室管理制度.docx VIP
- TCAZG 023-2024 动物园动物免疫接种指南.docx VIP
- 2024年北京门头沟区教育系统事业单位招聘教师3笔试真题.docx VIP
- 企业职工伤亡事故管理课程 .pptx VIP
- 国企领导班子2025年度民主生活会“五个带头”对照检查材料文稿.docx VIP
- PG6581B燃气轮发电机组使用维护说明书.pdf VIP
- 小学语文六年级上册期中模拟试卷(答案)(部编版).doc
原创力文档


文档评论(0)