- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
通讯录查询系统的设计与实现
一、需求分析
1、问题描述
为某个单位建立一个员工通讯录管理系统,可以方便查询每一个员工的电话与地址。设计散列表存储,设计并实现通讯录查找系统。
2、基本要求
a.每个记录有下列数据项:电话号码、用户名、地址;
b.从键盘输入各记录,分别以电话号码为关键字建立散列表;
c.采用二次探测再散列法解决冲突;
d.查找并显示给定电话号码的记录;
e.通讯录信息文件保存。
二、概要设计
1.数据结构
本程序需要用到两个结构体,分别为通讯录 message以及哈希表HxList
2.程序模块
本程序包含两个模块,一个是实现功能的函数的模块,另一个是主函数模块。
系统子程序及功能设计
本系统共有三个子程序,分别是:
int Hx(long long key,int data)//哈希函数
void BulidHx(HxList L)//建立通讯录
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;
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;
}
else
{
count++;
goto xunhuan;
}
}
else
{
site=L.number-abs(site);
if(L.list[site].phonenumber==-1)
{
pose=site;
}
else
{
count++;
goto xunhuan;
}
}
}
L.list[pose].phonenumber=key;
fprintf(f,%lld,key);
fprintf(f, );
L.list[pose].name=new char[strlen(buf)+1];
strcpy(L.list[pose].name,buf);
fprintf(f,%s,buf);
fprintf(f, );
L.list[pose].add=new char[strlen(str)+1];
strcpy(L.list[pose].add,str);
fprintf(f,%s,str);
fprintf(f,\
您可能关注的文档
最近下载
- 内地新疆高中班学生转学、休学审核表.pdf VIP
- GBT 18015.1-2017 数字通信用对绞或星绞多芯对称电缆 第1部分:总规范.pdf
- TJAASS 151-2024 水稻碳足迹评价方法.pdf VIP
- 新解读《GB_T 18015.1-2017数字通信用对绞或星绞多芯对称电缆 第1部分:总规范》最新解读.docx VIP
- 2022年苏州大学计算机科学与技术专业《计算机网络》科目期末试卷B(有答案).docx VIP
- 检验科仪器设备故障应急预案.docx VIP
- (27页PPT)K12教师试岗培训工作安排及其说明.pptx VIP
- 保姆带小孩合同协议书例文.pdf VIP
- 危重病人抢救应急演练方案.pdf
- XP-1A SF6定性检漏仪说明书.pdf VIP
原创力文档


文档评论(0)