- 1、本文档共17页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构哈希表(类)
PAGE
PAGE 1
《数 据 结 构》
课程设计说明书
题 目
哈希表的设计与实现
学 号
姓 名
指导教师
日 期
目录
TOC \o 1-3 \h \z \u HYPERLINK \l _Toc324926890第1章 需求分析 PAGEREF _Toc324926890 \h 2
HYPERLINK \l _Toc324926891第2章 总体设计 PAGEREF _Toc324926891 \h 4
HYPERLINK \l _Toc324926892第3章 抽象数据类型定义 PAGEREF _Toc324926892 \h 5
HYPERLINK \l _Toc3249268933.1 哈希表抽象数据类型的设计 PAGEREF _Toc324926893 \h 5
HYPERLINK \l _Toc324926895第4章 详细设计 PAGEREF _Toc324926895 \h 6
HYPERLINK \l _Toc3249268964.1 工程视图 PAGEREF _Toc324926896 \h 6
HYPERLINK \l _Toc3249268974.2 类图视图 PAGEREF _Toc324926897 \h 6
HYPERLINK \l _Toc3249268984.3 函数的调用关系 PAGEREF _Toc324926898 \h 6
HYPERLINK \l _Toc3249268994.4 主程序流程图 PAGEREF _Toc324926899 \h 8
HYPERLINK \l _Toc3249269004.5 主要算法的流程图 PAGEREF _Toc324926900 \h 9
HYPERLINK \l _Toc324926901第5章 测试 PAGEREF _Toc324926901 \h 10
HYPERLINK \l _Toc324926902第6章 总结 PAGEREF _Toc324926902 \h 13
HYPERLINK \l _Toc324926903附录:程序代码 PAGEREF _Toc324926903 \h 14
需求分析
1.1问题描述:
基本要求
1、设每个记录有下列数据项:电话号码、用户名、地址
2、从键盘输入各记录,分别以电话号码和用户名为关键字建立哈希表;
3、采用再哈希法解决冲突;
4、查找并显示给定电话号码的记录;
5、查找并显示给定用户名的记录。
6、在哈希函数确定的前提下,尝试各种不同类型处理冲突的方法(至少两种),考察平均查找长度的变化。
在链地址法中,每个结点对应一个链表结点,它由三个域组成,而由于该程序需要分别用电话号码和用户名为关键字建立哈希表,所以该链表结点它是由四个域组成,链地 址法结点结构如图:
name
phone
address
next
其中phone和name是分别为以电话号码和用户名为关键字域,存放关键字(key);address[为结点的数据域,用来存储用户的地址。Next指针是用来指向下一个结点的地址。
1.2类:
class node //定义储存学生信息的结构体
{public:
string phone;
string name;
string address;
node *next;
int hash(string key);
friend class hash;
};
class hash
{
public:
node *infor_phone[MAX]; //存放信息的指针数组
node *infor_name[MAX];
void find_byname(string name); //以名字为关键字查询用户信息
void find_byphone(string phone); //以电话为关键字查询用户信息
void find();
void findinfor(); //分别以名字和电话为关键字查询用户信息
void hash_frist();
void hash_second();
friend int hashed(string key); //链表法获得哈希码
void init(); //初始化初始化指针数组
bool usersayyes(
文档评论(0)