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;
}

最新文章

  1. vs2013 无法打开 源 文件 &quot;SDKDDKVer.h&quot;
  2. firefox vimperator插件
  3. Android带多选功能的PhotoPicker
  4. [USACO2005][POJ2226]Muddy Fields(二分图最小点覆盖)
  5. Sqlite: unable to open database file
  6. Universal-Image-Loader 基本使用
  7. Kaggle入门——使用scikit-learn解决DigitRecognition问题
  8. 使用 cnpm 加速 npm
  9. handler的使用
  10. C#的内存管理原理解析+标准Dispose模式的实现
  11. mybatis中两种取值方式?谈谈Spring框架理解?
  12. Kubernetes代码解读-apiserver之list-watch
  13. Harbor api 操作
  14. 在Windows系统上怎么使用SecureCRT链接Linux AWS EC2 -摘自网络
  15. Glusterfs3.3.1DHT(hash分布)源代码分析
  16. 一步步教你如何在 Visual Studio 2013 上使用 Github
  17. 关于Redis命令keys在性能方面的说明
  18. MySQL for Mac安装和启动
  19. EasyUI DataGrid 多级表头设置
  20. Hibernate 中的DetachedCriteria。

热门文章

  1. java——继承、抽象方法
  2. Codeforces Round #527 (Div. 3) C. Prefixes and Suffixes (思维,字符串)
  3. 洛谷 P5837 [USACO19DEC]Milk Pumping G (单源最短路,dijkstra)
  4. SpringSecurity认证流程
  5. involution 内卷化
  6. Express All In One
  7. VS Code Extension
  8. HTTP/2 &amp; Push Cache
  9. React LifeCycle API
  10. flutter 1.5 in action