日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

SDUT 3377 数据结构实验之查找五:平方之哈希表

發布時間:2023/12/13 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SDUT 3377 数据结构实验之查找五:平方之哈希表 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

數據結構實驗之查找五:平方之哈希表

Time Limit:?400MS?Memory Limit:?65536KB Submit?Statistic

Problem 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 30

Example Output

10 6 4 5 3 7 8 0 9 6 10 2 1

DQE:

哈希表平方探測法,注意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 数据结构实验之查找五:平方之哈希表的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。