bzoj4216: Pig

来源:互联网 发布:java中classpath和path 编辑:程序博客网 时间:2024/06/05 06:24

链接

  http://www.lydsy.com/JudgeOnline/problem.php?id=4216

题解

  今下午的我:这道题啊,闭着眼打完不用编译,交上去1A掉就行了!
  现在的我:这什么鬼题啊,快把我折腾死了。


  是分块不假,但是显然不能够N,因为那样会超时。
  那就小点,但也不能太小,我开的20,这样内存正好够用。
  块小了就会变多,又要超时,那就维护前缀和。
  于是我就
  第一次:MLE(数组开大)
  第二次:RE(sb错误)
  第三次:TLE(块太小没用前缀和)
  第四次:AC
  这个故事告诉我们:

不要小视任何一道题目。

代码

//分块#include <cstdio>#include <algorithm>#include <cmath>#define maxn 500010#define ll long longusing namespace std;ll s[26000];int a[maxn], size=20;inline ll read(ll x=0){    char c=getchar(); bool f=0;    while(c<48 or c>57)f=f or c=='-',c=getchar();    while(c>=48 and c<=57)x=(x<<1)+(x<<3)+c-48,c=getchar();    return f?-x:x;}inline ll q(ll l, ll r){    ll i, ans=0;    for(i=l;i/size==l/size and i<=r;i++)ans+=a[i];    if(l/size!=r/size)for(i=r;i/size==r/size;i--)ans+=a[i];    if(l/size!=r/size)ans+=s[r/size-1]-s[l/size];    return ans;}int main(){    ll i, N, M, t, l, r, lastans=0;    N=read(), M=read(), t=read();    for(i=1;i<=N;i++)a[i]=read(),s[i/size]+=a[i];    for(i=1;i<=N/size;i++)s[i]+=s[i-1];    for(i=1;i<=M;i++)    {        l=read(), r=read();        if(t)l=(l^abs(lastans))%N+1, r=(r^abs(lastans))%N+1;        if(l>r)swap(l,r);        printf("%lld\n",lastans=q(l,r));    }    return 0;}
0 0
原创粉丝点击