码迷,mamicode.com
首页 > 其他好文 > 详细

hdu 5183 Negative and Positive (NP)(STL-集合【HASH】)

时间:2015-03-11 21:20:46      阅读:143      评论:0      收藏:0      [点我收藏+]

标签:

题意:

When given an array (a0,a1,a2,?an1) and an integer K, you are expected to judge whether there is a pair (i,j)(0ij<n) which makes that NPsum(i,j) equals to K true. Here NPsum(i,j)=aiai+1+ai+2+?+(1)jiaj

1n1000000,1000000000ai1000000000,1000000000K1000000000

 

思路:

原先想是不是要用树状数组,,,,,,

其实只要线性扫,然后判断sum[i]-K在之前是不是出现过即可。

用map会超时,用set险过。。【set效率比map高?】

*:时时候整理一套自己的HASH了,,,,,

 

代码:

set<ll> st;
ll ans,K;
int n;
int T;
ll a[1000005];



int main(){

    cin>>T;
    rep(t,1,T){
        scanf("%d%I64d",&n,&K);
        rep(i,1,n){
            scanf("%I64d",&a[i]);
        }
        printf("Case #%d: ",t);

        ans=0;
        st.clear();
        st.insert(0);
        int  td=1;
        rep(i,1,n){
            ans+=(a[i]*td);
            if(st.find(ans-K)!=st.end()){
                puts("Yes.");
                goto NEXT;
            }
            if(td==-1){
                st.insert(ans);
            }
            td=-td;
        }

        st.clear();
        ans=0;
        td=-1;
        rep(i,1,n){
            ans+=(a[i]*td);
            if(st.find(ans-K)!=st.end()){
                puts("Yes.");
                goto NEXT;
            }
            if(td==-1){
                st.insert(ans);
            }
            td=-td;
        }
        puts("No.");

        NEXT:;
    }

    return 0;
}

 

hdu 5183 Negative and Positive (NP)(STL-集合【HASH】)

标签:

原文地址:http://www.cnblogs.com/fish7/p/4330831.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!