SDUT 3377 数据结构实验之查找五:平方之哈希表
生活随笔
收集整理的這篇文章主要介紹了
SDUT 3377 数据结构实验之查找五:平方之哈希表
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
數據結構實驗之查找五:平方之哈希表
Time Limit:?400MS?Memory Limit:?65536KB Submit?StatisticProblem Description
給定的一組無重復數據的正整數,根據給定的哈希函數建立其對應hash表,哈希函數是H(Key)=Key%P,P是哈希表表長,P是素數,處理沖突的方法采用平方探測方法,增量di=±i^2,i=1,2,3,...,m-1
Input
輸入一組測試數據,數據的第1行給出兩個正整數N(N <= 500)和P(P >= 2N的最小素數),N是要插入到哈希表的元素個數,P是哈希表表長;第2行給出N個無重復元素的正整數,數據之間用空格間隔。
Output
按輸入數據的順序輸出各數在哈希表中的存儲位置 (hash表下標從0開始),數據之間以空格間隔,以平方探測方法處理沖突。
Example Input
4 11 10 6 4 15 9 11 47 7 29 11 9 84 54 20 30Example Output
10 6 4 5 3 7 8 0 9 6 10 2 1DQE:
哈希表平方探測法,注意Di序列各個元素通過i計算得到的關系,每次計算記得對p取余即可~
1 #include <iostream> 2 #include <cstdio> 3 using namespace std; 4 int n,p; 5 6 int insert(int *f,int k) 7 { 8 int h=k%p; 9 int i=1,j=h; 10 while(f[j]!=0&&f[j]!=k) 11 { 12 int t=(i+1)/2; 13 j=(h+t*t*(i%2==0?-1:1))%p; 14 i++; 15 } 16 f[j]=k; 17 return j; 18 } 19 20 int main() 21 { 22 while(scanf("%d %d",&n,&p)!=EOF) 23 { 24 int hash[1011]={0}; 25 int i,k; 26 for(i=0;i<n;i++) 27 { 28 scanf("%d",&k); 29 printf("%d%c",insert(hash,k),i==n-1?'\n':' '); 30 } 31 } 32 return 0; 33 } 34 35 /*************************************************** 36 User name: *** 37 Result: Accepted 38 Take time: 0ms 39 Take Memory: 152KB 40 Submit time: 2016-12-03 13:06:06 41 ****************************************************/
轉載于:https://www.cnblogs.com/Leroscox/p/6128567.html
總結
以上是生活随笔為你收集整理的SDUT 3377 数据结构实验之查找五:平方之哈希表的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 5分钟卖了上百万的爆款 米家眼镜相机拆解
- 下一篇: 【转】应用架构一团糟?如何将单体应用改造