标签:include PAT 1078 int ++ MS false Hashing size
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;
}
标签:include,PAT,1078,int,++,MS,false,Hashing,size 来源: https://blog.csdn.net/seven_colors/article/details/123139546
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。