bzoj4216: Pig
来源:互联网 发布:java中classpath和path 编辑:程序博客网 时间:2024/06/05 06:24
链接
http://www.lydsy.com/JudgeOnline/problem.php?id=4216
题解
今下午的我:这道题啊,闭着眼打完不用编译,交上去1A掉就行了!
现在的我:这什么鬼题啊,快把我折腾死了。
是分块不假,但是显然不能够
那就小点,但也不能太小,我开的20,这样内存正好够用。
块小了就会变多,又要超时,那就维护前缀和。
于是我就
第一次:
第二次:
第三次:
第四次:
这个故事告诉我们:
不要小视任何一道题目。
代码
//分块#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
- 【BZOJ4216】Pig
- bzoj4216: Pig
- BZOJ4216【Pig】
- 【bzoj4216】 Pig 乱搞
- [BZOJ4216]Pig(分块)
- 【分块】BZOJ4216 Pig
- BZOJ4216 Pig 解题报告【卡空间】【数据结构】【分块】
- bzoj4216 -- 分块
- pig
- pig
- Pig
- Pig
- Pig
- Pig
- Pig
- pig
- 【pig】pig脚本规范
- plasma PIG
- 【机器学习 基本概念】泊松分布与指数分布
- SQLServer安装完成但失败,数据库引擎,server复制等安装失败的解决办法
- 【步骤】lwip-2.0.2在STM32F103RC+ENC28J60网卡上无操作系统移植(不使用STM32库函数)
- chrono学习笔记
- javascript的类型转换
- bzoj4216: Pig
- L1-039. 古风排版
- 51单片机的中断系统
- 初识Meteor
- 异或今日头条笔试
- HBase学习-表的增删改插
- 【机器学习 基本概念】高斯分布
- J2EE项目系列(四)--SSM框架构建积分系统和基本商品检索系统(Spring+SpringMVC+MyBatis+Lucene+Redis+MAVEN)(2)建立商品数据库和Lucene的搭建
- scrapy学习记录0401