hdu 5183 hash表

BC # 32 1002

题意:给出一个数组 a 和一个数 K ,问是否存在数对( i , j ),使 a   - a i + 1 +……+ (-1)j - i  a 

对于这道题,一开始就想到了是前缀和,但是如果只是记录下前缀和数组,那么查找就会成为一个大问题。补题的时候一开始考虑用 hash 数组或者是 set 存,但是很明显 TLE 了,在翔神的推荐下,我研究了一下 hash表的创建过程,惊奇地发现,其实就是建了一个 HashMap 结构体,而里面放了这个表所用的数组以及相应操作的函数。其中创建 HashMap 就是将表的大小(size)定为0,然后将所有值所指的头定为 -1 ,插入数值操作完全和创建链式前向星一样,只是只有一条链而链式前向星有多个点的多条链而已,而查找 Hash 值也是和链式前向星的遍历一样。

 1 #include<stdio.h>
 2 #include<string.h>
 3 #define ll long long
 4
 5 const int MAXM=1000007;
 6 ll a[MAXM];
 7
 8 ll read(){
 9     ll f=1,x=0;
10     char c=getchar();
11     while(c>‘9‘||c<‘0‘){
12         if(c==‘-‘)f=-1;
13         c=getchar();
14     }
15     while(c<=‘9‘&&c>=‘0‘){
16         x=x*10+c-‘0‘;
17         c=getchar();
18     }
19     return x*f;
20 }
21
22 struct HashMap{
23     int next[MAXM],head[MAXM],size;
24     ll state[MAXM];
25     void init(){
26         size=0;
27         memset(head,-1,sizeof(head));
28     }
29     bool check(ll val){
30         int h=(val%MAXM+MAXM)%MAXM;
31         for(int i=head[h];~i;i=next[i]){
32             if(state[i]==val)return 1;
33         }
34         return 0;
35     }
36     bool insert(ll val){
37         int h=(val%MAXM+MAXM)%MAXM;
38         for(int i=head[h];~i;i=next[i]){
39             if(state[i]==val)return 1;
40         }
41         state[size]=val;
42         next[size]=head[h];
43         head[h]=size++;
44         return 0;
45     }
46 }H1,H2;
47
48 int main(){
49     int T;
50     while(scanf("%d",&T)!=EOF){
51         for(int q=1;q<=T;q++){
52             H1.init();
53             H1.insert(0);
54             H2.init();
55     //        H2.insert(0);
56             int n,k;
57             n=read();
58             k=read();
59             int i;
60             ll s=0;
61             bool f=0;
62             for(i=0;i<n;i++) a[i]=read();
63             for(i=0;i<n&&!f;i++){
64                 if(i&1){
65                     s-=a[i];/*
66                     if(H1.check(s-k)){
67                         f=1;
68                     }
69                     H1.insert(s);*/
70                 }
71                 else{
72                     s+=a[i];/*
73                     if(H2.check(-s-k)){
74                         f=1;
75                     }
76                     H2.insert(-s);*/
77                 }
78                 if(H1.check(s-k)||H2.check(-s-k))f=1;
79                 if(i&1){
80                     H1.insert(s);
81                 }
82                 else H2.insert(-s);
83             }
84             if(f)printf("Case #%d: Yes.\n",q);
85             else printf("Case #%d: No.\n",q);
86         }
87     }
88     return 0;
89 }

时间: 2024-10-06 01:09:58

hdu 5183 hash表的相关文章

HDU 5183 Negative and Positive (NP) ——(后缀和+手写hash表)

根据奇偶开两个hash表来记录后缀和.注意set会被卡,要手写hash表. 具体见代码: 1 #include <stdio.h> 2 #include <algorithm> 3 #include <string.h> 4 using namespace std; 5 const int N = 1000000 + 10; 6 const int HASH = 1000000 + 7; 7 typedef long long ll; 8 struct hashmap

Hash表的表大小

hash表的出现主要是为了对内存中数据的快速.随机的访问.它主要有三个关键点:Hash表的大小.Hash函数.冲突的解决. 这里首先谈谈第一点:Hash表的大小. Hash表的大小一般是定长的,如果太大,则浪费空间,如果太小,冲突发生的概率变大,体现不出效率.所以,选择合适的Hash表的大小是Hash表性能的关键. 对于Hash表大小的选择通常会考虑两点: 第一,确保Hash表的大小是一个素数.常识告诉我们,当除以一个素数时,会产生最分散的余数,可能最糟糕的除法是除以2的倍数,因为这只会屏蔽被除

南阳OJ-138 找球号(二)(hash表应用)

找球号(二) 时间限制:1000 ms  |  内存限制:65535 KB 难度:5 描述 在某一国度里流行着一种游戏.游戏规则为:现有一堆球中,每个球上都有一个整数编号i(0<=i<=100000000),编号可重复,还有一个空箱子,现在有两种动作:一种是"ADD",表示向空箱子里放m(0<m<=100)个球,另一种是"QUERY",表示说出M(0<M<=100)个随机整数ki(0<=ki<=100000100),分

python 字典有序无序及查找效率,hash表

刚学python的时候认为字典是无序,通过多次插入,如di = {}, 多次di['testkey']='testvalue' 这样测试来证明无序的.后来接触到了字典查找效率这个东西,查了一下,原来字典在python内部是通过哈希表的顺序来排的,做了一些测试,比如di = {1:1,3:3,2:2,4:4,5:5} ,无论怎么改变键值对的顺序,print di 总是会{1: 1, 2: 2, 3: 3, 4: 4, 5: 5}.所以看起来当插入di['key']='value'时,这组键值对有时

hash表总结

Hash表也称散列表,也有直接译作哈希表,Hash表是一种特殊的数据结构,它同数组.链表以及二叉排序树等相比较有很明显的区别,它能够快速定位到想要查找的记录,而不是与表中存在的记录的关键字进行比较来进行查找.这个源于Hash表设计的特殊性,它采用了函数映射的思想将记录的存储位置与记录的关键字关联起来,从而能够很快速地进行查找. 1.Hash表的设计思想 对于一般的线性表,比如链表,如果要存储联系人信息: 张三 13980593357 李四 15828662334 王五 13409821234 张

nyist oj 138 找球号(二)(hash 表+位运算)

找球号(二) 时间限制:1000 ms  |  内存限制:65535 KB 难度:5 描述 在某一国度里流行着一种游戏.游戏规则为:现有一堆球中,每个球上都有一个整数编号i(0<=i<=100000000),编号可重复,还有一个空箱子,现在有两种动作:一种是"ADD",表示向空箱子里放m(0<m<=100)个球,另一种是"QUERY",表示说出M(0<M<=100)个随机整数ki(0<=ki<=100000100),分

数据结构与算法-hash表

前言 哈希表是一种存放键-值对的数据结构,其中值用来存放我们真正需要的数据,键的主要目的就是为了找到值.哈希表理想情况下,只需要一次hash计算即可找到值数据,但通常情况下我们不需要耗费巨大的额外空间来追求这丝毫的查找速度(要追求低hash冲突率,必然要扩大hash表),我们更希望的是让空间和时间达到某种平衡,这可以通过调节hash函数来解决(装填因子). 装填因子=表中的记录数/哈希表的长度,如果装填因子越小,表明表中还有很多的空单元,则发生冲突的可能性越小:而装填因子越大,则发生冲突的可能性

hash表的建立和查找

(1)冲突处理方法为:顺次循环后移到下一个位置,寻找空位插入.(2)BKDE 字符串哈希unsigned int hash_BKDE(char *str){/* 初始种子seed 可取31 131 1313 13131 131313 etc.. */unsigned int seed = 131;unsigned int hash = 0;while (*str){hash = hash * seed + (*str++);}return (hash & 0x7FFFFFFF);} 选做内容每一

Hash表的C++实现(转)

原文:Hash表(C++实现) 哈希表的几个概念: 映像:由哈希函数得到的哈希表是一个映像. 冲突:如果两个关键字的哈希函数值相等,这种现象称为冲突. 处理冲突的几个方法: 1.开放地址法:用开放地址处理冲突就是当冲突发生时,形成一个地址序列,沿着这个序列逐个深测,直到找到一个“空”的开放地址,将发生冲突的关键字值存放到该地址中去. 例如:hash(i)=(hash(key)+d(i)) MOD m (i=1,2,3,......,k(k<m-1)) d为增量函数,d(i)=d1,d2,d3,.