【1078】Hashing (25 分)

简介: 【1078】Hashing (25 分)【1078】Hashing (25 分)
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<string.h>
#include<algorithm>  
#include<map>
#include<vector>
#include<queue> 
using namespace std;  
key:散列函数H(key)=key%TSize,解决冲突使用二次方探查法
可证明得:如果步长step从0~TSize-1枚举仍然无法找到位置,则step≥TSize也不可能找到位置了
const int N=11111;
bool isPrime(int n){  //判断n是否素数
  if(n <= 1)  return false;
  int sqr=(int)sqrt(1.0*n);
  for(int i=2;i<=sqr;i++){ 
    if(n%i == 0)  return false;
  }
  return true;
}
bool hashTable[N]={0};//hashTable[x] == false 则x号位未被使用
int main(){   
  int n,TSize,a;
  scanf("%d%d",&TSize,&n);
  while(isPrime(TSize) == false){  //寻找第一个≥TSize的质数
    TSize++;
  }
  for(int i=0;i<n;i++){ 
    scanf("%d",&a);
    int M=a%TSize; 
    if(hashTable[M] == false) {  //如果M号位未被使用,则已找到
      hashTable[M]=true;
      if(i == 0)  printf("%d",M);
      else printf(" %d",M);
    }else {
      int step; //二次方探查法步长
      for(step=1;step < TSize ;step++){  //可以证明TSize为循环节
        M=(a+step*step)%TSize;  //下一次检测值
        if(hashTable[M] == false){  //如果M号位置未被使用,则已找到
          hashTable[M]=true;
          if(i == 0)  printf(" %d",M);
          else printf(" %d",M);
          break;//记住要break
        }
      }
      if(step >=TSize){  //找不到插入的地方
        if(i >0) printf(" ");
        printf("-");
      }
    }
  }        
  system("pause"); 
    return 0;   
}
相关文章
|
8月前
|
算法 测试技术 C++
【动态规划】【C++算法】2518. 好分区的数目
【动态规划】【C++算法】2518. 好分区的数目
问题 A: DS哈希查找—线性探测再散列
问题 A: DS哈希查找—线性探测再散列
122 0
|
5月前
|
存储 缓存 负载均衡
Rendezvous hashing算法介绍
Rendezvous hashing算法介绍
92 3
Rendezvous hashing算法介绍
|
存储 缓存 算法
【第五天】算法图解--哈希表(散列表)Hash函数
【第五天】算法图解--哈希表(散列表)Hash函数
|
存储 缓存 负载均衡
【算法技术专题】如何用Java实现一致性 hash 算法( consistent hashing )(上)
【算法技术专题】如何用Java实现一致性 hash 算法( consistent hashing )(上)
341 0
【算法技术专题】如何用Java实现一致性 hash 算法( consistent hashing )(上)
ML之Hash_EditDistance:基于输入图片哈希化(均值哈希+差值哈希)即8*8个元素的单向vector利用编辑距离算法进行判别
ML之Hash_EditDistance:基于输入图片哈希化(均值哈希+差值哈希)即8*8个元素的单向vector利用编辑距离算法进行判别
ML之Hash_EditDistance:基于输入图片哈希化(均值哈希+差值哈希)即8*8个元素的单向vector利用编辑距离算法进行判别
【1145】Hashing - Average Search Time (25分)【hash 平方探测法】
【1145】Hashing - Average Search Time (25分)【hash 平方探测法】 【1145】Hashing - Average Search Time (25分)【hash 平方探测法】
115 0
【1134】Vertex Cover (25分)【hash散列】
【1134】Vertex Cover (25分)【hash散列】 【1134】Vertex Cover (25分)【hash散列】
109 0
【1125】Chain the Ropes (25分)【排序 贪心】
【1125】Chain the Ropes (25分)【排序 贪心】 【1125】Chain the Ropes (25分)【排序 贪心】
86 0
【1122】Hamiltonian Cycle (25分)【图论】
【1122】Hamiltonian Cycle (25分)【图论】 【1122】Hamiltonian Cycle (25分)【图论】
114 0

热门文章

最新文章