题目描述

神犇SJY虐完HEOI之后给傻×LYD出了一题:

SHY是T国的公主,平时的一大爱好是作诗。

由于时间紧迫,SHY作完诗之后还要虐OI,于是SHY找来一篇长度为N的文章,阅读M次,每次只阅读其中连续的一段[l,r],从这一段中选出一些汉字构成诗。因为SHY喜欢对偶,所以SHY规定最后选出的每个汉字都必须在[l,r]里出现了正偶数次。而且SHY认为选出的汉字的种类数(两个一样的汉字称为同一种)越多越好(为了拿到更多的素材!)。于是SHY请LYD安排选法。

LYD这种傻×当然不会了,于是向你请教……

问题简述:N个数,M组询问,每次问[l,r]中有多少个数出现正偶数次。

输入输出格式

输入格式:

输入第一行三个整数n、c以及m。表示文章字数、汉字的种类数、要选择M次。

第二行有n个整数,每个数Ai在[1, c]间,代表一个编码为Ai的汉字。

接下来m行每行两个整数l和r,设上一个询问的答案为ans(第一个询问时ans=0),令L=(l+ans)mod n+1, R=(r+ans)mod n+1,若L>R,交换L和R,则本次询问为[L,R]。

输出格式:

输出共m行,每行一个整数,第i个数表示SHY第i次能选出的汉字的最多种类数。

输入输出样例

输入样例#1:

5 3 5
1 2 2 3 1
0 4
1 2
2 2
2 3
3 5
输出样例#1:

2
0
0
0
1

说明

对于100%的数据,1<=n,c,m<=10^5

题解

  1.我们考虑一下分块的话要每一块都保存是正偶数的数字的个数,用一个ans[i][j]保存第i块到第j块内符合条件的数字的个数,o(1)的查询,前缀和的思想

  2.在最左端的最右端的用一个统计数组暴力即可

  3.但是要记住最左端和最右端的数字要与整个[l,r]区间相关联,所以用一个sum[i][j]保存第[i]块第[j]种颜色的数量

  4.luogu上记得开02....

// luogu-judger-enable-o2
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<iostream>
using namespace std;
const int N=;
int ch[N],bl[N],cnt[N],ans[][],sum[][N];
int l[N],r[N],n,m,c,last,tmp,res;
int read()
{
int x=,w=;char ch=getchar();
while(ch>''||ch<''){if(ch=='-')w=-;ch=getchar();}
while(ch>=''&&ch<='')x=x*+ch-'',ch=getchar();
return x*w;
} /*int prep(int x)
{
return (x+last)%n+1;
}*/ void build()
{
for(int i=;i<=tmp;i++)
l[i]=(i-)*tmp+,r[i]=tmp*i;
r[tmp]=n;
for(int i=;i<=n;i++)
{
bl[i]=(i-)/(tmp)+;
sum[bl[i]][ch[i]]++;
}
for(int i=;i<=n;i++)
for(int j=;j<=tmp;j++)
{
sum[j][i]+=sum[j-][i];
}
for(int i=;i<=tmp;i++)
{
int now=;
for(int j=l[i];j<=n;j++)
{
++cnt[ch[j]];
if (!(cnt[ch[j]] & )) ++now;
else if (cnt[ch[j]] > ) --now;
ans[i][bl[j]]=now;
}
for(int j=l[i];j<=n;j++)
--cnt[ch[j]];
}
} int query(int x,int y)
{
x=(x+res)%n+;y=(y+res)%n+;
if(x>y)swap(x,y);
res=;
if(bl[y]<=bl[x]+)
{
for(int i=x;i<=y;i++)
{
++cnt[ch[i]];
if(!(cnt[ch[i]]&))res++;
else if(cnt[ch[i]]>)res--;
}
for(int i=x;i<=y;i++)--cnt[ch[i]];
return last=res;
}
res=ans[bl[x]+][bl[y]-];
for(int i=x;i<=r[bl[x]];i++)
{
++cnt[ch[i]];
if(!((cnt[ch[i]]+sum[bl[y]-][ch[i]]-sum[bl[x]][ch[i]])&))++res;
else if(cnt[ch[i]]+sum[bl[y]-][ch[i]]-sum[bl[x]][ch[i]]>)--res;
}
for (int i=l[bl[y]];i<=y;++i)
{
++cnt[ch[i]];
if(!((cnt[ch[i]]+sum[bl[y]-][ch[i]]-sum[bl[x]][ch[i]])&))++res;
else if(cnt[ch[i]]+sum[bl[y]-][ch[i]]-sum[bl[x]][ch[i]]>)--res;
}
for(int i=x;i<=r[bl[x]];i++)--cnt[ch[i]];
for(int i=l[bl[y]];i<=y;i++)--cnt[ch[i]];
return last=res;
} int main()
{
n=read();c=read();m=read();tmp=sqrt(n);
tmp++;
for(int i=;i<=n;i++)ch[i]=read();
build();
while(m--)
{
int x=read(),y=read();
printf("%d\n",query(x,y));
}
return ;
}

作诗(si)[分块]的更多相关文章

  1. 【BZOJ2821】作诗(Poetize) 分块

    Description 神犇SJY虐完HEOI之后给傻×LYD出了一题:SHY是T国的公主,平时的一大爱好是作诗.由于时间紧迫,SHY作完诗之后还要虐OI,于是SHY找来一篇长度为N的文章,阅读M次, ...

  2. 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 ...

  3. BZOJ2821 作诗(Poetize) 分块

    题意 算法 经验总结 代码 题意 不带修改,查询数列[1,n]中[l,r]内的出现正偶数次的数的个数, 数列中的数 <= 1e5, n <= 1e5, 强制在线 算法 ​ 查询的内容: 区 ...

  4. BZOJ 2821作诗(Poetize) 分块

    Description 有一个长度为n的序列,序列每个元素的范围[1,c],有m个询问x y,表示区间[x,y]中出现正偶数次的数的种类数. Solution 大力分块解决问题. 把序列分块,f[i] ...

  5. 洛谷 P4135 作诗(分块)

    题目链接 题意:\(n\) 个数,每个数都在 \([1,c]\) 中,\(m\) 次询问,每次问在 \([l,r]\) 中有多少个数出现偶数次.强制在线. \(1 \leq n,m,c \leq 10 ...

  6. BZOJ2821 作诗(分块)

    和区间众数几乎一模一样的套路. // luogu-judger-enable-o2 #include<iostream> #include<cstdio> #include&l ...

  7. 「luogu4135」作诗

    「luogu4135」作诗 传送门 分块好题. 预处理出 \(f[i][j]\) 表示 \(i\) 号块到 \(j\) 号块的答案,\(num[i][k]\) 表示 \(k\) 在前 \(i\) 块的 ...

  8. 【分块】BZOJ2821 作诗(Poetize)

    2821: 作诗(Poetize) Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 3265  Solved: 951[Submit][Status][ ...

  9. BZOJ2821 作诗(Poetize) 【分块】

    BZOJ2821 作诗(Poetize) Description 神犇SJY虐完HEOI之后给傻×LYD出了一题: SHY是T国的公主,平时的一大爱好是作诗. 由于时间紧迫,SHY作完诗之后还要虐OI ...

随机推荐

  1. Java8新特性 利用流和Lambda表达式对List集合进行处理

    Lambda表达式处理List 最近在做项目的过程中经常会接触到 lambda 表达式,随后发现它基本上可以替代所有 for 循环,包括增强for循环.也就是我认为,绝大部分的for循环都可以用 la ...

  2. 【原创】VSFTP: Login failure: 530 Login incorrect的解决办法

    1.修改/etc/vsftpd/ftpusers和/etc/vsftpd/user_list中关于root的行,注释掉即可: 2.关闭SELinux:如果不想关闭的话,可以打开home项的布林值:se ...

  3. 关于js里的document.compatmode

    document.compatmode为获取页面的渲染模式. 其中有两个渲染模式 1.CSS1Compat(标准模式).浏览器宽度:document.documentElement.clientHei ...

  4. js闭包详解-转自好友trigkit4

    闭包(closure)是Javascript语言的一个难点,也是它的特色,很多高级应用都要依靠闭包实现. 闭包的特性 闭包有三个特性: 1.函数嵌套函数 2.函数内部可以引用外部的参数和变量 3.参数 ...

  5. OUTLOOK网站直接点击发送邮件

    下面的样式是用文字来做链接的:<a href="mailto:邮箱地址" alt="点击此链接给我写信">网页上显示的文字</a> 下面 ...

  6. checkbox控制显示隐藏

    显示文本框<input type = "checkbox" id="checkbox" onclick="on_hide();"/&g ...

  7. NOIp模拟赛三十

    心态崩了的一天 先Orz yrx 开场五分钟yrx大吼一声:“这B题不是原题吗” hjw:“对哦好像我也做过哦” 过了十分钟yrx又大吼一声:“这C题我也做过啊,洪水那题啊” 于是 像我这种傻逼A题一 ...

  8. 洛谷 P2738 [USACO4.1]篱笆回路Fence Loops

    P2738 [USACO4.1]篱笆回路Fence Loops 题目描述 农夫布朗的牧场上的篱笆已经失去控制了.它们分成了1~200英尺长的线段.只有在线段的端点处才能连接两个线段,有时给定的一个端点 ...

  9. 转载:爱加密邀您参加5月17日深圳App开发沙龙活动

    听闻,移动互联网的九大门派已集结在一起,各路顶尖高手携App修炼宝典九阴真经现身,一场席卷全国的App修炼风暴即将来临.5月17日,以“移动开发者如何白手起家.快速盈利”为主题的沙龙活动将在深圳市南山 ...

  10. scratchIDE使用说明

    scratchIDE使用说明