BZOJ_2821_作诗(Poetize)_分块
BZOJ_2821_作诗(Poetize)_分块
Description
Input
Output
输出共m行,每行一个整数,第i个数表示SHY第i次能选出的汉字的最多种类数。
Sample Input
1 2 2 3 1
0 4
1 2
2 2
2 3
3 5
Sample Output
0
0
0
1
HINT
对于100%的数据,1<=n,c,m<=10^5
用一个前缀桶记录一下前缀块中每个数出现的次数。
然后处理出ans[i][j]表示从i块到j块这部分的答案。
查询时一个块内直接暴力,
否则用和统计ans[i][j]差不多的方法统计零散部分的答案。
代码:
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
using namespace std;
#define N 100050
#define M 318
int n,m,C,pos[N],L[M],R[M],ans[M][M],h[M][N],size,block,a[N],w[N],b[N];
int solve(int l,int r) {
int p=pos[l],q=pos[r],re=0,i;
if(p==q) {
for(i=l;i<=r;i++) {
w[a[i]]++;
if(w[a[i]]!=1) {
if(w[a[i]]%2==0) re++;
else re--;
}
}
for(i=l;i<=r;i++) w[a[i]]=0;
}else {
re=ans[p+1][q-1];
b[0]=0;
for(i=l;i<=R[p];i++) b[++b[0]]=a[i];
for(i=L[q];i<=r;i++) b[++b[0]]=a[i];
for(i=1;i<=b[0];i++) {
if(w[b[i]]==0) {
w[b[i]]=h[q-1][b[i]]-h[p][b[i]]+1;
if(w[b[i]]!=1) {
if(w[b[i]]%2==0) re++;
else re--;
}
}else {
w[b[i]]++;
if(w[b[i]]%2==0) re++;
else re--;
}
}
for(i=1;i<=b[0];i++) w[b[i]]=0;
}
return re;
}
int main() {
scanf("%d%d%d",&n,&C,&m);
int i,j,k; size=sqrt(n); block=n/size;
for(i=1;i<=block;i++) {
L[i]=R[i-1]+1; R[i]=i*size;
for(j=1;j<=C;j++) h[i][j]=h[i-1][j];
for(j=L[i];j<=R[i];j++) {
scanf("%d",&a[j]); pos[j]=i; h[i][a[j]]++;
}
}
if(R[block]!=n) {
block++; L[block]=R[block-1]+1; R[block]=n;
for(i=1;i<=C;i++) h[block][i]=h[block-1][i];
for(i=L[block];i<=n;i++) {
scanf("%d",&a[i]); pos[i]=block; h[block][a[i]]++;
}
}
for(i=1;i<=block;i++) {
for(j=i;j<=block;j++) {
ans[i][j]=ans[i][j-1];
for(k=L[j];k<=R[j];k++) {
if(w[a[k]]==0) {
w[a[k]]=h[j-1][a[k]]-h[i-1][a[k]]+1;
if(w[a[k]]!=1) {
if(w[a[k]]%2==0) ans[i][j]++;
else ans[i][j]--;
}
}
else {
w[a[k]]++;
if(w[a[k]]%2==0) ans[i][j]++;
else ans[i][j]--;
}
}
for(k=L[j];k<=R[j];k++) w[a[k]]=0;
}
}
int lstans=0,x,y;
while(m--) {
scanf("%d%d",&x,&y);
x=(x+lstans)%n+1;
y=(y+lstans)%n+1;
if(x>y) swap(x,y);
lstans=solve(x,y);
printf("%d\n",lstans);
}
}
BZOJ_2821_作诗(Poetize)_分块的更多相关文章
- BZOJ2821 作诗(Poetize) 【分块】
BZOJ2821 作诗(Poetize) Description 神犇SJY虐完HEOI之后给傻×LYD出了一题: SHY是T国的公主,平时的一大爱好是作诗. 由于时间紧迫,SHY作完诗之后还要虐OI ...
- [BZOJ 2821] 作诗(Poetize) 【分块】
题目链接:BZOJ - 2821 题目分析 因为强制在线了,所以无法用莫队..可以使用分块来做. 做法是,将 n 个数分成 n/x 个块,每个块大小为 x .先预处理出 f[i][j] ,表示从第 i ...
- 2018.09.30 bzoj2821: 作诗(Poetize)(分块)
传送门 分块经典题目. 先将数列分块. 然后预处理出每两个块之间有多少个数出现了正偶数次. 这样查询的时候对于中间的完整块直接用预处理出的数组搞定. 剩下的暴力枚举求解. 代码: #include&l ...
- BZOJ 2821: 作诗(Poetize)( 分块 )
分块,分成N^0.5块.O(N^1.5)预处理出sm[i][j]表示前i块中j的出现次数, ans[i][j]表示第i~j块的答案. 然后就可以O(N^0.5)回答询问了.总复杂度O((N+Q)N^0 ...
- 【分块】BZOJ2821 作诗(Poetize)
2821: 作诗(Poetize) Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 3265 Solved: 951[Submit][Status][ ...
- 2821: 作诗(Poetize)
2821: 作诗(Poetize) Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 1078 Solved: 348[Submit][Status] ...
- 【BZOJ2821】作诗(Poetize) 分块
Description 神犇SJY虐完HEOI之后给傻×LYD出了一题:SHY是T国的公主,平时的一大爱好是作诗.由于时间紧迫,SHY作完诗之后还要虐OI,于是SHY找来一篇长度为N的文章,阅读M次, ...
- 巴蜀4384 -- 【模拟试题】作诗(Poetize)
Description 神犇SJY虐完HEOI之后给傻×LYD出了一题:SHY是T国的公主,平时的一大爱好是作诗.由于时间紧迫,SHY作完诗之后还要虐OI,于是SHY找来一篇长度为N的文章,阅读M次, ...
- 【bzoj2821】作诗(Poetize)
*题目描述: 神犇SJY虐完HEOI之后给傻×LYD出了一题:SHY是T国的公主,平时的一大爱好是作诗.由于时间紧迫,SHY作完诗 之后还要虐OI,于是SHY找来一篇长度为N的文章,阅读M次,每次只阅 ...
随机推荐
- PHP include和require 区别
require 的使用方法如 require("MyRequireFile.php"); .这个函数通常放在 PHP 程序的最前面,PHP 程序在执行前,就会先读入 require ...
- 成为七牛云 Contributor -如何贡献 logkit 代码
logkit 是 Pandora 开源的一个通用的日志收集工具,可以将不同数据源的数据方便的发送到 Pandora 进行数据分析.除了基本的数据发送功能,logkit 还有容错.并发.监控.删除等功能 ...
- ubuntu 18.04取消自动锁屏以及设置键盘快捷锁屏
1:操作设置取消自动锁屏: setting-->power--->never 2: 设置自动锁屏快捷键: 快捷键设置一般在setting-->devices--->keybo ...
- mysql免安装版配置使用
mysql免安装版配置使用 1.下载解压 2.配置环境变量 变量MYSQL_HOME = 解压目录 配置变量path 编辑,在后面加上 ;%MYSQL_HOME%\bin 3.修改配置文件 增加或 ...
- 【收藏】下载Chrome商店插件的方法,万恶的gwd
以下是下载离线插件包的方法: 第一步: 每个Google Chrome扩展都有一个固定的ID,例如https://chrome.google.com/webstore/detail/bfbmjmiod ...
- ie6 js报错汇总
假如ie6是一个非美女的人,那不知道为多少人乱刀砍多少次,假如不幸它是一个美女,那不知道要被多少人轮奸完之后还是乱刀砍死. ie6的js的错误说明总是很隐晦的,它喜欢和捉迷藏.报的行数和错误,常常不知 ...
- poj3532求生成树中最大权与最小权只差最小的生成树+hoj1598俩个点之间的最大权与最小权只差最小的路经。
该题是最小生成树问题变通活用,表示自己开始没有想到该算法:先将所有边按权重排序,然后枚举最小边,求最小生成树(一个简单图的最小生成树的最大权是所有生成树中最大权最小的,这个容易理解,所以每次取最小边, ...
- Mac BOOK PRO U盘安装windows7、8及8.1
http://v.youku.com/v_show/id_XMTI1NjgzMzU0NA==.html http://jingyan.baidu.com/article/1709ad80b3d2f44 ...
- arcengine 文件夹连接
Provides access to members that manages a GX catalog. Product Availability Available with ArcGIS Des ...
- Go---设计模式(策略模式)
策略模式定义了算法家族,在调用算法家族的时候不感知算法的变化,客户也不会受到影响. 下面用<大话设计模式>中的一个实例进行改写. 例:超市中经常进行促销活动,促销活动的促销方法就是一个个策 ...