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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

1078 Hashing (25 分)【难度: 一般 / 知识点: 哈希表二次探测法】

發(fā)布時(shí)間:2025/3/20 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 1078 Hashing (25 分)【难度: 一般 / 知识点: 哈希表二次探测法】 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.


https://pintia.cn/problem-sets/994805342720868352/problems/994805389634158592
不得不說(shuō),讀了半天的假題,以為就是直接判斷可不可以插入就行了。
后來(lái),發(fā)現(xiàn)是用只具有正增量的二次探測(cè)法來(lái)解決沖突。
不得不說(shuō),PAT的題還是很不錯(cuò)的,考的是一些數(shù)據(jù)結(jié)構(gòu)方面的一些內(nèi)功,不是偏競(jìng)賽的那種思維的。
考察的就是基本算法概念用算法來(lái)實(shí)現(xiàn)。
首先,先介紹一下二次探測(cè)法
關(guān)于二次探測(cè)法(處理沖突方法):pos=(key + i*i )%MSize,其中i為 1*1 , -1*1 , 2*2 , -2*2 , ··· k*k , -k*k (k <= MSize-1)
題目說(shuō)的是只具有正增量的二次探測(cè)法故pos=(key + i*i )%MSize,其中i為 1*1 , 2*2 , ··· k*k (k <= MSize-1)

#include<bits/stdc++.h> using namespace std; const int N=1e7+10; const int null=0x3f3f3f3f; int hush[N],n,m; int insert(int x) {for(int i=0;i<m;i++){int pos=(x+i*i)%m;if(hush[pos]==null)//找到位置了{hush[pos]=x;return pos;}}return -1; } bool check(int x) {if(x==1) return true;for(int i=2;i<=x/i;i++) if(x%i==0) return true;return false; } int main(void) {memset(hush,0x3f,sizeof hush);cin>>m>>n;while(check(m)) m++;//求最小的質(zhì)數(shù)for(int i=1;i<=n;i++){int x; cin>>x;int ans=insert(x);if(ans==-1) cout<<"-";else cout<<ans;if(i!=n) cout<<" ";}return 0; }

總結(jié)

以上是生活随笔為你收集整理的1078 Hashing (25 分)【难度: 一般 / 知识点: 哈希表二次探测法】的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。