yangzhixiaohuli 发表于 6 天前

构造散列表

设散列表a,散列函数是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++怎么做

FishC 发表于 6 天前

以下是使用C++编写的程序代码,以开放地址法解决散列表的冲突问题:

#include <iostream>
#include <vector>
using namespace std;

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

// 定义散列函数
int hashFunction(int k) {
    return k % TABLE_SIZE;
}

// 查找插入位置
int findPosition(vector<int>& table, int key) {
    int hashValue = hashFunction(key);
    int i = 0;
    while (table[(hashValue + 5 * i) % TABLE_SIZE] != -1) {
      i++;
    }
    return (hashValue + 5 * i) % TABLE_SIZE;
}

int main() {
    int n;// 输入个数
    cin >> n;

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

    for (int i = 0; i < n; ++i) {
      int value;
      cin >> value;

      int pos = findPosition(table, value);
      table = value;// 插入值

      cout << value << " pos: " << pos << endl;
    }

    return 0;
}

**说明:**

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

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

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
页: [1]
查看完整版本: 构造散列表