赞
踩
关注博主不迷路,博主带你码代码!
7
17718881666 chen hunan
12837192867 yuan hubei
18998239899 duan loudi
13689721388 qian hefei
19999999999 zhang beijing
12673678523 liu liuan
13876352729 luo fujian
菜单页面
添加电话
查询电话
修改信息
删除电话
退出系统
哈希函数
key 值的确定是按照电话号码的求和 % MAXSIZE所得的
% MAXSIZE 的原因是因为放置下标越界
int GetHashKey(char ar[])
{
int len = strlen(ar);
int key = 0;
int i;
for(i = 0; i < len; i ++ )
{
key += ar[i] - ‘0’;
}
return key % MAXSIZE;
}
冲突处理
哈希冲突处理,这里采用的是二次探测法,将 Cay 分为两种情况,当 Cay 为奇数的时候,我们向后探测,当 Cay 为偶数的时候,我们向前探测,不管在向前还是向后探测,我们都要对其取模,防止下标越界,但是在向后探测的时候,可能是负数,为了方便取模,我们对于负数的时候就直接跳过就好了。
//冲突处理,二次探测再散列
int HandleCollision(HashTable table, int key)
{
Czy = 1; //从2,3,4,5,…
while(1)
{
Czy ++ ; //从2,3,4,5,…
if(Czy % 2 == 0)
{
if(table->data[
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。