鱼C论坛

 找回密码
 立即注册
查看: 446|回复: 1

构造散列表

[复制链接]
发表于 2024-12-15 14:09:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
设散列表a[18],散列函数是hask(k)=k%17,用开放地址法解决冲突h
i
​
=(h
0
​
+d
i
​
)%m。冲突时,使用增量序列d
i
​
=5i。计算输入序列(值>=0)对应的散列地址值。(输入个数不会超过15个)

输入格式:
第一行为输入个数;

第二行为对应的输入值,用空格隔开。

输出格式:
按输入顺序输出其散列地址。每行对应一个值及其散列地址,中间用空格隔开(即pos前后均有一个空格)

输入样例:
5
141 73 95 112 56
输出样例:
141 pos: 5
73 pos: 10
95 pos: 15
112 pos: 2
56 pos: 7

这题用C语言或者C++怎么做
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2024-12-15 14:09:48 | 显示全部楼层
以下是使用C++编写的程序代码,以开放地址法解决散列表的冲突问题:

  1. #include <iostream>
  2. #include <vector>
  3. using namespace std;

  4. // 定义散列表的大小
  5. const int TABLE_SIZE = 17;

  6. // 定义散列函数
  7. int hashFunction(int k) {
  8.     return k % TABLE_SIZE;
  9. }

  10. // 查找插入位置
  11. int findPosition(vector<int>& table, int key) {
  12.     int hashValue = hashFunction(key);
  13.     int i = 0;
  14.     while (table[(hashValue + 5 * i) % TABLE_SIZE] != -1) {
  15.         i++;
  16.     }
  17.     return (hashValue + 5 * i) % TABLE_SIZE;
  18. }

  19. int main() {
  20.     int n;  // 输入个数
  21.     cin >> n;

  22.     vector<int> table(TABLE_SIZE, -1);  // 初始化散列表

  23.     for (int i = 0; i < n; ++i) {
  24.         int value;
  25.         cin >> value;

  26.         int pos = findPosition(table, value);
  27.         table[pos] = value;  // 插入值

  28.         cout << value << " pos: " << pos << endl;
  29.     }

  30.     return 0;
  31. }
复制代码


**说明:**

1. **hashFunction**: 计算给定键的初始散列值。  
2. **findPosition**: 利用增量序列 \(d_i = 5i\) 计算并查找适合插入的空位置。  
3. **main函数**: 通过输入获取数据并利用以上函数找出适合的位置,然后输出值和位置。  

将以上代码复制并在C++编译器中执行即可获得对应的输出结果。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-7 07:06

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表