HASH 大量插入与查询
生活随笔
收集整理的这篇文章主要介绍了
HASH 大量插入与查询
小编觉得挺不错的,现在分享给大家,帮大家做个参考.
描述在某一国度里流行着一种游戏。游戏规则为:现有一堆球中,每个球上都有一个整数编号i(0<=i<=100000000),编号可重复,还有一个空箱子,现在有两种动作:一种是"ADD",表示向空箱子里放m(0<m<=100)个球,另一种是"QUERY”,表示说出M(0<M<=100)个随机整数ki(0<=ki<=100000100),分别判断编号为ki 的球是否在这个空箱子中(存在为"YES",否则为"NO"),先答出者为胜。现在有一个人想玩玩这个游戏,但他又很懒。他希望你能帮助他取得胜利。 输入第一行有一个整数n(0<n<=10000);
随后有n行;
每行可能出现如下的任意一种形式:
第一种:
一个字符串"ADD",接着是一个整数m,随后有m个i;
第二种:
一个字符串"QUERY”,接着是一个整数M,随后有M个ki;
输出输出每次询问的结果"YES"或"NO". 样例输入 2
ADD 5 34 343 54 6 2
QUERY 4 34 54 33 66 样例输出 YES
YES
NO
NO
随后有n行;
每行可能出现如下的任意一种形式:
第一种:
一个字符串"ADD",接着是一个整数m,随后有m个i;
第二种:
一个字符串"QUERY”,接着是一个整数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; }
总结
以上是生活随笔为你收集整理的HASH 大量插入与查询的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: POJ-1840 Eqs Hash
- 下一篇: 网络最大流(SAP)模板