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

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

生活随笔

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

编程问答

HASH 大量插入与查询

發(fā)布時(shí)間:2025/6/15 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 HASH 大量插入与查询 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

描述
在某一國(guó)度里流行著一種游戲。游戲規(guī)則為:現(xiàn)有一堆球中,每個(gè)球上都有一個(gè)整數(shù)編號(hào)i(0<=i<=100000000),編號(hào)可重復(fù),還有一個(gè)空箱子,現(xiàn)在有兩種動(dòng)作:一種是"ADD",表示向空箱子里放m(0<m<=100)個(gè)球,另一種是"QUERY”,表示說(shuō)出M(0<M<=100)個(gè)隨機(jī)整數(shù)ki(0<=ki<=100000100),分別判斷編號(hào)為ki 的球是否在這個(gè)空箱子中(存在為"YES",否則為"NO"),先答出者為勝。現(xiàn)在有一個(gè)人想玩玩這個(gè)游戲,但他又很懶。他希望你能幫助他取得勝利。 輸入
第一行有一個(gè)整數(shù)n(0<n<=10000);
隨后有n行;
每行可能出現(xiàn)如下的任意一種形式:
第一種:
一個(gè)字符串"ADD",接著是一個(gè)整數(shù)m,隨后有m個(gè)i;
第二種:
一個(gè)字符串"QUERY”,接著是一個(gè)整數(shù)M,隨后有M個(gè)ki;

輸出
輸出每次詢問(wèn)的結(jié)果"YES"或"NO".
樣例輸入
2 ADD 5 34 343 54 6 2 QUERY 4 34 54 33 66
樣例輸出
YES YES NO NO

需要大量插入 檢索 ? ?哈希表的插入和檢索效率高

#include<iostream> #include<cstdio> #include<cstring> #include<string> #include<time.h> #include<algorithm> using namespace std; #define N 1000010 #define CLR(arr, what) memset(arr, what, sizeof(arr)) const int fib = 111123; int Key[N], Head[N], Next[N]; int top; void add(int n) { int temp; temp = n % fib; Key[top] = n; Next[top] = Head[temp]; Head[temp] = top; top++; } int main() { int ncase; char str[8]; int num, number; bool flag; CLR(Key, 0); CLR(Head, -1); top = 0; flag = false; scanf("%d", &ncase); while(ncase--) { scanf("%s", str); if(str[0] == 'A') { scanf("%d", &num); for(int i = 0; i < num; ++i) { scanf("%d", &number); add(number); } } else { scanf("%d", &num); for(int i = 0; i < num; ++i) { scanf("%d", &number); int temp = number % fib; for(int j = Head[temp]; j != -1; j = Next[j]) if(Key[j] == number) { flag = true; break; } printf(flag == true ? "YES\n" : "NO\n"); flag = false; } } } return 0; }



總結(jié)

以上是生活随笔為你收集整理的HASH 大量插入与查询的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

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