PAT-1078 Hashing

1078 Hashing

part 3, 3.1

自己解法

  • 注意最后一个点需要处理二次探测
#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>

bool isPrime(int m)
{
    if (m <= 1)
        return false;
    for (int i = 2; i < m; i++)
        if (m % i == 0)
            return false;
    return true;
}

int main()
{
    int MS, N;
    cin >> MS >> N;
    int a, x;
    if (isPrime(MS) == false)
        for (; isPrime(MS) == false; MS++)
            ;
    vector<int> s(MS, -1);
    for (int i = 0; i < N; i++)
    {
        cin >> a;
        x = a % MS;
        if (s[x] < 0)
        {
            s[x] = a;
            cout << x;
        }
        else
        {
            int flag = 0;
            for (int j = 1; j < MS - 1; j++)
                if (s[(a + j * j) % MS] < 0)
                {
                    s[(a + j * j) % MS] = a;
                    cout << (a + j * j) % MS;
                    flag = 1;
                    break;
                }
            if (flag == 0)
                cout << "-";
        }
        if (i != N - 1)
            cout << " ";
    }
    cout << endl;
    system("pause");
    return 0;
}

大神解法

  • 柳神
#include <iostream>
using namespace std;
int size, n, hashTable[10100];
bool isprime(int num) {
    if(num == 1) return false;
    for(int i = 2; i * i <= num; i++)
        if(num % i == 0) return false;
    return true;
}
void insert(int key) {
    for(int step = 0; step < size; step++) {
        int index = (key + step * step) % size;
        if(hashTable[index] == 0) {
            hashTable[index] = 1;
            cout << index % size;
            return ;
        }
    }
    cout << '-';
}
int main() {
    cin >> size >> n;
    while(!isprime(size)) size++;
    for(int i = 0; i < n; i++) {
        int key;
        cin >> key;
        if(i != 0) cout << ' ';
        insert(key);
    }
    return 0;
}
上一篇:Error: package or namespace load failed for ‘ggplot2’ in loadNamespace(i, c(lib.loc, .libPaths()), v


下一篇:数据结构(1)