noi.ac #553 序列
【题目描述】
老虎和蒜头是好朋友。
众所周知,蒜头经常给老虎出一些题目,而老虎也常常被难倒,作为捧杯之王的老虎难免心有怨怼。今天,老虎发现了蒜头的一个序列 a 。虽然老虎不知道这个序列是用来做什么的,但老虎还是希望搞点破坏——他计划把序列 a 全部变成 0 。
然而,对蒜头的序列进行操作绝不是容易的事情。具体来说,老虎每次可以选择两个位置 i,j(i≠j) ,将 ai 和 aj 变为 ai⊕aj,其中 ⊕ 是异或操作。
然而,只将蒜头的一个序列变成 0 实在是不够解气。因此,老虎希望你能够对于 m 组询问 l,r ,告诉老虎对于该序列的一个子序列 al,al+1,…,ar,最少需要操作几次才能将该序列变为全 0 序列。
【输入格式】
输入的第一行包括两个正整数 n,m ,表示序列的长度和询问的次数。
接下来 m 行,每行两个正整数 li,ri ,表示一组询问。
【输出格式】
输出共 m 行,每行一个数,表示该组询问最少的操作次数。
【样例数据】
input
5 3
3 3 3 3 5
1 5
2 3
3 5
output
4
1
3
【数据范围】
对于 100% 的数据,0≤ai<230。
Subtask 1(20 分): 2≤n,m≤10
Subtask 2(30 分): 2≤n,m≤2000
Subtask 3(50 分): 2≤n,m≤2×105
时间限制: 2s
空间限制: 512MB
很显然,对于一段区间,如果有相同的数,那么一次可以消掉两个。如果两个数不同,那么两次就能消掉(它们两个碰两次),如果有单个的,需要两次才能消掉(一次和0,一次它们两个相消)。
很显然,我们只需要维护一段区间中相同的数的个数,和落单的数的个数,这个每次拓展一位是很好处理的。
所以上莫队就行了。QAQ
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define MAXN 200010
using namespace std;
int n,m,block,cur_ans,sum1;
int a[MAXN],b[MAXN],pos[MAXN],ans[MAXN],sum[MAXN];
struct Node{int id,l,r;}node[MAXN];
inline bool cmp(struct Node x,struct Node y)
{return pos[x.l]<pos[y.l]||(pos[x.l]==pos[y.l]&&x.r<y.r);}
inline void ins(int x)
{
if(!x) return;
if(sum[x]%2==1)
{
if(sum1&1) cur_ans--,sum1=0;
else cur_ans++,sum1=1;
}
else
{
if(sum1&1) sum1=0;
else cur_ans+=2,sum1=1;
}
sum[x]++;
}
inline void del(int x)
{
if(!x) return;
if(sum[x]%2==1)
{
if(sum1&1) cur_ans-=2,sum1=0;
else sum1=1;
}
else
{
if(sum1&1) cur_ans--,sum1=0;
else cur_ans++,sum1=1;
}
sum[x]--;
}
int main()
{
#ifndef ONLINE_JUDGE
freopen("ce.in","r",stdin);
#endif
scanf("%d%d",&n,&m);
block=(int)sqrt(1.0*n);
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
memcpy(b,a,sizeof(a));
sort(&b[1],&b[n+1]);
int k=unique(&b[1],&b[n+1])-b-1;
for(int i=1;i<=n;i++) a[i]=lower_bound(&b[1],&b[k+1],a[i])-b;
for(int i=1;i<=n;i++)
{
pos[i]=i/block;
if(i%block) pos[i]++;
}
for(int i=1;i<=m;i++)
{
scanf("%d%d",&node[i].l,&node[i].r);
node[i].id=i;
}
sort(&node[1],&node[m+1],cmp);
int l=1,r=0;
for(int i=1;i<=m;i++)
{
// printf("%d %d\n",node[i].l,node[i].r);
while(r<node[i].r) r++,ins(a[r]);
while(l>node[i].l) l--,ins(a[l]);
while(l<node[i].l) del(a[l]),l++;
while(r>node[i].r) del(a[r]),r--;
ans[node[i].id]=cur_ans;
}
for(int i=1;i<=m;i++) printf("%d\n",ans[i]);
return 0;
}
noi.ac #553 序列的更多相关文章
- NOI.ac #31 MST DP、哈希
题目传送门:http://noi.ac/problem/31 一道思路好题考虑模拟$Kruskal$的加边方式,然后能够发现非最小生成树边只能在一个已经由边权更小的边连成的连通块中,而树边一定会让两个 ...
- NOI.AC NOIP模拟赛 第五场 游记
NOI.AC NOIP模拟赛 第五场 游记 count 题目大意: 长度为\(n+1(n\le10^5)\)的序列\(A\),其中的每个数都是不大于\(n\)的正整数,且\(n\)以内每个正整数至少出 ...
- NOI.AC NOIP模拟赛 第一场 补记
NOI.AC NOIP模拟赛 第一场 补记 candy 题目大意: 有两个超市,每个超市有\(n(n\le10^5)\)个糖,每个糖\(W\)元.每颗糖有一个愉悦度,其中,第一家商店中的第\(i\)颗 ...
- noi.ac上的一套(假)NOI题
noi.ac上的一套(假)NOI题 本来想着可以刷点通过量的,结果发现好像并不是这样的. 整数 description 给你\(n,p\),要你求\(\sum_{k=1}^n\sum_{i=1}^k\ ...
- SDOI2015 寻宝游戏 | noi.ac#460 tree
题目链接:戳我 可以知道,我们相当于是把有宝藏在的地方围了一个圈,求这个圈最小是多大. 显然按照dfs序来遍历是最小的. 那么我们就先来一遍dfs序列,并且预处理出来每个点到根的距离(这样我们就可用\ ...
- NOI.AC#2139-选择【斜率优化dp,树状数组】
正题 题目链接:http://noi.ac/problem/2139 题目大意 给出\(n\)个数字的序列\(a_i\).然后选出一个不降子序列最大化子序列的\(a_i\)和减去没有任何一个数被选中的 ...
- NOI.AC#2144-子串【SAM,倍增】
正题 题目链接:http://noi.ac/problem/2144 题目大意 给出一个字符串\(s\)和一个序列\(a\).将字符串\(s\)的所有本质不同子串降序排序后,求有多少个区间\([l,r ...
- # NOI.AC省选赛 第五场T1 子集,与&最大值
NOI.AC省选赛 第五场T1 A. Mas的童年 题目链接 http://noi.ac/problem/309 思路 0x00 \(n^2\)的暴力挺简单的. ans=max(ans,xor[j-1 ...
- NOI.AC NOIP模拟赛 第六场 游记
NOI.AC NOIP模拟赛 第六场 游记 queen 题目大意: 在一个\(n\times n(n\le10^5)\)的棋盘上,放有\(m(m\le10^5)\)个皇后,其中每一个皇后都可以向上.下 ...
随机推荐
- windows上pip安装及使用详解
windows上pip安装及使用详解 2018-11-21 19:49:58 十二笔 阅读数 8229更多 分类专栏: Python学习 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA ...
- 这周末又参加班里同学生日party,同学父母包场2小时花费大约1000美金左右。
今天班上Claire的生日,邀请了几个小朋友去pump it up.特别特别开心,因为她父母选的时间特别好晚上6-8点小孩子玩疯了以后吃的特别多.
- 在django中部署vue项目,不单独抽离dist文件
1,在django项目下(app所在目录),新建vue项目,使用脚手架构建vue项目,vue create (项目名) 2,构建好以后,配置django: (1),配置settings: · 修改te ...
- Python实现读取Excel文档中的配置并下载软件包
问题:现在遇到这样一个问题,服务器存储了很多软件包,这些包输入不同的产品,每个产品都有自己的配置,互相交叉,那么到底某一产品所有配置的软件包下载后,占用多大空间呢? 分析:从这个问题入手,了解到:软件 ...
- 关于IDEA导入依赖问题,阿里云下载不了
关于阿里云,有部分数据是不能够下载的,就拿ojdbc8-12.2.0.1.0.jar来说 pom.xml <!--Oracle驱动 因为maven仓库下载不了,采用本地导入--> < ...
- Delphi最新的路线图
没想到,官方又发布了一个路线图,同上一个相比,多了10.3.3版本,而其中,最主要的iOS 13支持,即下半年发布的新的苹果系统,再一个就是android 64的delphi支持!年底前发布,够官忙伙 ...
- windows 下 node 入门
node js node -v npm -v nvm v nvm list npm install * -g npm install express -g npm install -g expres ...
- C++实例 分解质因数
分解质因数: 每个合数都可以写成几个质数相乘的形式.其中每个质数都是这个合数的因数,叫做这个合数的分解质因数.分解质因数只针对合数. 分解质因数的算式叫短除法.求一个数分解质因数,要从最小的质数除起, ...
- idea中添加mybatis mapper 样例
代码: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC &quo ...
- 网络协议相关面试问题-https加密算法相关面试问题
密钥: 密钥是一种参数,它是在使用密码cipher算法过程中输入的参数,同一个明文在相同的密码算法和不同的密钥计算下会产生不同的密文.所以说算法既使公开了但是密钥参数不同其结果也是不同的,其中关于明文 ...