PAT-1145(Hashing - Average Search Time)哈希表+二次探测解决冲突
2024-09-07 16:00:16
Hashing - Average Search Time
PAT-1145
- 需要注意本题的table的容量设置
- 二次探测,只考虑正增量
- 这里计算平均查找长度的方法和书本中的不同
#include<iostream>
#include<cstring>
#include<string>
#include<algorithm>
#include<cstdio>
#include<sstream>
#include<set>
#include<map>
#include<cmath>
using namespace std;
const int maxn=10004;
int table[100*maxn];
int size,n,m;
bool isPrime(int n){
if(n<=1){
return false;
}
for(int i=2;i*i<=n;i++){
if(n%i==0)
return false;
}
return true;
}
int findPrime(int n){
while(!isPrime(n)){
n++;
}
return n;
}
bool insertHash(int n){
int ori=n;
bool flag=false;
for(int j=0;j<size;j++){
if(table[(n+j*j)%size]==-1){
table[(n+j*j)%size]=ori;
flag=true;
break;
}
}
return flag;
}
int findHash(int n){
//返回次数
int ans=0;
for(int j=0;j<=size;j++){
ans++;
if(table[(n+j*j)%size]==-1||table[(n+j*j)%size]==n)
break;
}
return ans;
}
int main(){
memset(table,-1,sizeof(table));
cin>>size>>n>>m;
size=findPrime(size);
for(int i=0;i<n;i++){
int a;
cin>>a;
if(!insertHash(a)){
cout<<a<<" cannot be inserted."<<endl;
}
}
int sums=0;
for(int i=0;i<m;i++){
int b;
cin>>b;
sums+=findHash(b);
}
printf("%.1lf\n",sums*1.0/m);
return 0;
}
最新文章
- vs2013 无法打开 源 文件 ";SDKDDKVer.h";
- firefox vimperator插件
- Android带多选功能的PhotoPicker
- [USACO2005][POJ2226]Muddy Fields(二分图最小点覆盖)
- Sqlite: unable to open database file
- Universal-Image-Loader 基本使用
- Kaggle入门——使用scikit-learn解决DigitRecognition问题
- 使用 cnpm 加速 npm
- handler的使用
- C#的内存管理原理解析+标准Dispose模式的实现
- mybatis中两种取值方式?谈谈Spring框架理解?
- Kubernetes代码解读-apiserver之list-watch
- Harbor api 操作
- 在Windows系统上怎么使用SecureCRT链接Linux AWS EC2 -摘自网络
- Glusterfs3.3.1DHT(hash分布)源代码分析
- 一步步教你如何在 Visual Studio 2013 上使用 Github
- 关于Redis命令keys在性能方面的说明
- MySQL for Mac安装和启动
- EasyUI DataGrid 多级表头设置
- Hibernate 中的DetachedCriteria。
热门文章
- java——继承、抽象方法
- Codeforces Round #527 (Div. 3) C. Prefixes and Suffixes (思维,字符串)
- 洛谷 P5837 [USACO19DEC]Milk Pumping G (单源最短路,dijkstra)
- SpringSecurity认证流程
- involution 内卷化
- Express All In One
- VS Code Extension
- HTTP/2 &; Push Cache
- React LifeCycle API
- flutter 1.5 in action