HASH 大量插入与查询
生活随笔
收集整理的這篇文章主要介紹了
HASH 大量插入与查询
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
描述在某一國度里流行著一種游戲。游戲規(guī)則為:現(xiàn)有一堆球中,每個球上都有一個整數(shù)編號i(0<=i<=100000000),編號可重復(fù),還有一個空箱子,現(xiàn)在有兩種動作:一種是"ADD",表示向空箱子里放m(0<m<=100)個球,另一種是"QUERY”,表示說出M(0<M<=100)個隨機(jī)整數(shù)ki(0<=ki<=100000100),分別判斷編號為ki 的球是否在這個空箱子中(存在為"YES",否則為"NO"),先答出者為勝。現(xiàn)在有一個人想玩玩這個游戲,但他又很懶。他希望你能幫助他取得勝利。 輸入第一行有一個整數(shù)n(0<n<=10000);
隨后有n行;
每行可能出現(xiàn)如下的任意一種形式:
第一種:
一個字符串"ADD",接著是一個整數(shù)m,隨后有m個i;
第二種:
一個字符串"QUERY”,接著是一個整數(shù)M,隨后有M個ki;
輸出輸出每次詢問的結(jié)果"YES"或"NO". 樣例輸入 2
ADD 5 34 343 54 6 2
QUERY 4 34 54 33 66 樣例輸出 YES
YES
NO
NO
隨后有n行;
每行可能出現(xiàn)如下的任意一種形式:
第一種:
一個字符串"ADD",接著是一個整數(shù)m,隨后有m個i;
第二種:
一個字符串"QUERY”,接著是一個整數(shù)M,隨后有M個ki;
需要大量插入 檢索 ? ?哈希表的插入和檢索效率高
#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 大量插入与查询的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: POJ-1840 Eqs Hash
- 下一篇: 网络最大流(SAP)模板