数据结构课程设计-通讯录查询系统的设计与实现.docxVIP

数据结构课程设计-通讯录查询系统的设计与实现.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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,\

文档评论(0)

134****7338 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档