使用除留余数法构造哈希函数
使用线性探测法来解决冲突
#include<iostream>
using namespace std;
const int MAX = 65535; //设置一个不可能输入的值
//建立哈希表
void Creat_HashTable(int *arr, int num)
{
int x = 0, key = 0; // x 为将要输入的值, key 为键值下标
//初始化哈希表为MAX
for (int i = 0; i < num; i++)
{
arr[i] = MAX;
}
cout << "请输入" << num << "个非零整数:" << endl;
for (int j = 0; j < num; j++)
{
//输入
cin >> x;
if (x == MAX)
{
//如果输入是MAX,跳出本轮循环进行下一轮循环
continue;
}
else
{
//如果不是MAX,在哈希表中找到可存入的下标
key = x % num;
}
while (arr[key] != MAX)
{
//如果表中已经有数值存入,循环找到空位
key = (key + 1) % num;
}
//存入
arr[key] = x;
}
}
//哈希函数(哈希查找)
void Hash_Search(int *arr, int num, int target)
{
int key = 0, count = 0;
//根据建表时的下标找到键值
key = target % num;
//如果第一次找不到
while (arr[key] != target && ++count <= num)
{
key = (key + 1) % num;
}
if (count > num)
{
cout << "找不到!" << endl;
}
else
{
cout << "找到了!在下标为" << key << "的单元中!" << endl;
}
}
int main()
{
int num = 0, target = 0;
cout << "请输入要建立的序列个数:" << endl;
cin >> num;
//动态创建一个哈希表
int *arr = new int[num];
Creat_HashTable(arr, num);
cout << "哈希表为:" << endl;
for (int i = 0; i < num; i++)
{
cout << arr[i] << "\t";
}
cout << endl;
while (target != 65535)
{
cout << "请输入要查找的键值:" << endl;
cin >> target;
Hash_Search(arr, num, target);
}
system("pause");
return 0;
}
本文介绍如何使用除留余数法构造哈希函数,并通过线性探测法解决哈希冲突,实例演示了在C++中创建哈希表的过程和哈希查找操作。
341

被折叠的 条评论
为什么被折叠?



