返回介绍

二、代码

发布于 2025-02-17 12:55:35 字数 1017 浏览 0 评论 0 收藏 0

代码中用到了函数指针,函数指针的用法参考 函数指针总结

//Hash.h
#include <iostream>
using namespace std;

int m, NIL = 0;
//11.4 开放寻址法
typedef int (*Probing)(int k, int i);
int h(int k)
{
  return k % m;
}
int h2(int k)
{
  return 1 + k % (m-1);
}
//线性探测
int Linear_Probing(int k, int i)
{
  return (h(k) + i) % m;
}
//二次探测
int Quadratic_Probint(int k, int i)
{
  int c1 = 1, c2 = 3;
  return (h(k) + c1 * i + c2 * i * i) % m;
}
//双重探测
int Double_Probint(int k, int i)
{
  return (h(k) + i * h2(k)) % m;
}
int Hash_Insert(int *T, int k, Probing p)
{
  int i = 0, j;
  do{
    j = p(k, i);
    if(T[j] == NIL)
    {
      T[j] = k;
      return j;
    }
    i++;
  }
  while(i != m);
  cout<<"error:hash table overflow"<<endl;
}

int Hash_Search(int *T, int k, Probing p)
{
  int i = 0, j;
  while(1)
  {
    j = p(k, i);
    if(T[j] == NIL || i == m)
      break;
    if(T[j] == k)
      return j;
    i++;
  }
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文