题意:

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

思路:

把N个数分成sqrt(n)块,预处理d[i][j]表示第i块起点到第j块末尾的答案

枚举起点i,并维护一个数组记录每个数到目前为止出现的次数,从偶变奇、从奇变偶时相应增减答案。

把每个数在数列中出现的位置从小到大排序后放入到一个数组Arr中备用。

读入每个询问[l,r]。如果l和r在同一个块中暴力即可,否则设l所在块的末尾为l’,r所在块的起点为r’,[l’+1,r’-1]的答案已经预处理出。扫描l~l’, r’~r的所有数,统计每个数出现的次数cnt,第一次出现时把它加入队列。

对于队列中的每个数,在数组Arr中二分l’+1和r’-1,得到在[l’+1,r’-1]中出现的次数k。通过对k和当前队列中的数的cnt进行奇偶性讨论更新答案

(from lyd的题解…)

我们就可以vector +lower_bound()

搞定~

(也可以用可持久化线段树之类的东西…)

最后  祝他们幸福……

  1. //By SiriusRen
  2. #include <cmath>
  3. #include <vector>
  4. #include <cstdio>
  5. #include <cstring>
  6. #include <algorithm>
  7. using namespace std;
  8. const int N=100005;
  9. int n,c,m,a[N],Block,block[N],f[1111][1111],vis[N],ans,l,r,stk[N],top;
  10. vector<int>vec[N];
  11. int main(){
  12. scanf("%d%d%d",&n,&c,&m),Block=sqrt(n);
  13. for(int i=1;i<=n;i++)scanf("%d",&a[i]),block[i]=(i-1)/Block+1,vec[a[i]].push_back(i);
  14. for(int i=1;i<=block[n];i++){
  15. memset(vis,0,sizeof(vis));int temp=0;
  16. for(int j=lower_bound(block,block+1+n,i)-block;j<=n;j++){
  17. vis[a[j]]++;
  18. if(vis[a[j]]%2==0)temp++;
  19. else if(vis[a[j]]!=1)temp--;
  20. if(block[j]!=block[j+1])f[i][block[j]]=temp;
  21. }
  22. }
  23. memset(vis,0,sizeof(vis));
  24. for(int i=1;i<=m;i++){
  25. scanf("%d%d",&l,&r);
  26. l=(l+ans)%n+1,r=(r+ans)%n+1;
  27. if(l>r)swap(l,r);ans=0;
  28. int L=block[l]+1,R=block[r];
  29. if(L<R){
  30. int ll=lower_bound(block+1,block+1+n,L)-block-1;
  31. int rr=lower_bound(block+1,block+1+n,R)-block;
  32. R--;top=0;
  33. for(int i=l;i<=ll;i++)vis[a[i]]++,stk[++top]=a[i];
  34. for(int i=rr;i<=r;i++)vis[a[i]]++,stk[++top]=a[i];
  35. ans=f[L][R];
  36. for(int i=1;i<=top;i++)if(vis[stk[i]]){
  37. int t=lower_bound(vec[stk[i]].begin(),vec[stk[i]].end(),rr)-
  38. lower_bound(vec[stk[i]].begin(),vec[stk[i]].end(),ll+1);
  39. if(!t){if(vis[stk[i]]%2==0)ans++;}
  40. else if(t%2==0){if(vis[stk[i]]%2==1)ans--;}
  41. else if(t%2==1&&vis[stk[i]]%2==1)ans++;
  42. vis[stk[i]]=0;
  43. }
  44. }
  45. else{
  46. top=0;
  47. for(int i=l;i<=r;i++)vis[a[i]]++;
  48. for(int i=l;i<=r;i++)if(vis[a[i]]){
  49. if(vis[a[i]]%2==0)ans++;
  50. vis[a[i]]=0;
  51. }
  52. }
  53. printf("%d\n",ans);
  54. }
  55. }

BZOJ 2821 分块+二分的更多相关文章

  1. bzoj 2821 分块处理

    大题思路就是分块,将n个数分成sqrt(n)个块,然后 处理出一个w数组,w[i,j]代表第i个块到第j个块的答案 那么对于每组询问l,r如果l,r在同一个块中,直接暴力做就行了 如果不在同一个块中, ...

  2. bzoj 2821 分块

    分块: 先预处理,将原序列分成长度为len的许多块,计算从第i块到第j块的答案,(可以做到O(n*n/len)). 每次询问时,将询问的区间分成三部分,:左边,中间,右边,中间是尽量大的一个块区间,其 ...

  3. [BZOJ 2821] 作诗(Poetize) 【分块】

    题目链接:BZOJ - 2821 题目分析 因为强制在线了,所以无法用莫队..可以使用分块来做. 做法是,将 n 个数分成 n/x 个块,每个块大小为 x .先预处理出 f[i][j] ,表示从第 i ...

  4. BZOJ 3343: 教主的魔法(分块+二分查找)

    BZOJ 3343: 教主的魔法(分块+二分查找) 3343: 教主的魔法 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1172  Solved:  ...

  5. Bzoj 3343: 教主的魔法(分块+二分答案)

    3343: 教主的魔法 Time Limit: 10 Sec Memory Limit: 256 MB Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息 ...

  6. [BZOJ 2821] 作诗

    Link: BZOJ 2821 传送门 Solution: 一道类似区间众数的经典分块 由于个数为偶数这样的条件不能支持快速合并 因此要先$O(n*sqrt(n))$预处理出$pre[i][j]$表示 ...

  7. BZOJ_3343_教主的魔法_分块+二分查找

    BZOJ_3343_教主的魔法_分块+二分查找 题意:教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列被编号为 ...

  8. 【bzoj2957】楼房重建 分块+二分查找

    题目描述 小A的楼房外有一大片施工工地,工地上有N栋待建的楼房.每天,这片工地上的房子拆了又建.建了又拆.他经常无聊地看着窗外发呆,数自己能够看到多少栋房子.为了简化问题,我们考虑这些事件发生在一个二 ...

  9. 【bzoj2453】维护队列/【bzoj2120】数颜色 分块+二分

    题目描述 你小时候玩过弹珠吗? 小朋友A有一些弹珠,A喜欢把它们排成队列,从左到右编号为1到N.为了整个队列鲜艳美观,小朋友想知道某一段连续弹珠中,不同颜色的弹珠有多少.当然,A有时候会依据个人喜好, ...

随机推荐

  1. 剖析Promise内部结构,一步一步实现一个完整的、能通过所有Test case的Promise类

    本文写给有一定Promise使用经验的人,如果你还没有使用过Promise,这篇文章可能不适合你,建议先了解Promise的使用 Promise标准解读 1.只有一个then方法,没有catch,ra ...

  2. 1) 十分钟学会android--建立第一个APP,创建android项目

    一个Android项目包含了所有构成Android应用的源代码文件. 本小节介绍如何使用Android Studio或者是SDK Tools中的命令行来创建一个新的项目. Note:在此之前,我们应该 ...

  3. hdu1829 A Bug's Life 基础种类并查集

    题目的大意可以理解为:A爱B,B爱C ……给出一系列爱恋的关系,推断有没有同性恋. 思路是把相同性别的归为一个集合(等价类),异性的异性为同性. #include<iostream> #i ...

  4. QT4.8界面设计(MSVC2010X)

    1.C++ IDE设计 MFC这种半死不活的windows C++平台已经被抛弃,很无奈.转向Qt的C++还是不错的选择. QT的QML才是最新的亮点,可惜没有时间经历这些东西了. 2.程序代码 2. ...

  5. Django 了解

    Django是一个开放源代码的Web应用框架 Django也是一个基于 MVC 构造的框架. 但是在Django中,控制器接受用户输入的部分由框架自行处理,所以 Django 里更关注的是模型(Mod ...

  6. Asp.net Core 源码-UrlExtensions

    using Microsoft.AspNetCore.Http; namespace SportsStore.Infrastructure { public static class UrlExten ...

  7. BZOJ 1602: [Usaco2008 Oct]牧场行走 倍增裸题

    Description N头牛(2<=n<=1000)别人被标记为1到n,在同样被标记1到n的n块土地上吃草,第i头牛在第i块牧场吃草. 这n块土地被n-1条边连接. 奶牛可以在边上行走, ...

  8. K3 新单到老单关联字段的添加

    新单到老单字段的添加分为两种: 一种为文本字段信息的关联,新单与老单字段的信息均为文本字段: 另一种为基础资料信息的关联,新单与老单均为基础资料字段信息.       K3 WISE 11.0中存储老 ...

  9. HTML5 Canvas绘制的下雪效果

    在HTML页面的HEAD区域直接引入snow.js即可,如下:<script type="text/javascript" src="js/snow.js" ...

  10. jmeter图片的下载

    1.jmeter下载文件 首先添加一个线程组,然后在线程组里面添加一个http请求,因为是获取数据,所有是get请求,写好下载的地址 1.添加线程组 :右键测试计划,添加-Threads(Users) ...