BZOJ3236: [AHOI2013]作业
BZOJ3236: [AHOI2013]作业
题目描述
行,我知道是Please contact lydsy2012@163.com!
题目分析
这题两问还是非常,emmmm。
首先第一问非常好解决,随便就可以用各种各样的方法求出来。
考虑第二问,明显可以让人想到莫队。通过在颜色上分块就可以快速解决问题。
离散化还是要离散化的,luogu数据比较毒。
是代码呢
#include <bits/stdc++.h>
using namespace std;
const int MAXN=1e6+7;
const int inf=1e9+7;
struct Q{
int l,r,a,b,id,ans1,ans2;
inline bool operator <(const Q &rhs)const{
return id<rhs.id;
}
}q[MAXN];
int L[MAXN],R[MAXN],st[MAXN],sum[MAXN],T[MAXN],sumk[MAXN],belong[MAXN],col[MAXN],change[MAXN];
int n,m,a[MAXN],b[MAXN],t;
inline bool cmp(Q x,Q y){return belong[x.l]==belong[y.l]?x.r<y.r:x.l<y.l;}
inline void add(int x){sum[col[x]]++;sumk[belong[col[x]]]++;if(sum[col[x]]==1) change[belong[col[x]]]++;}
inline void del(int x){sum[col[x]]--;sumk[belong[col[x]]]--;if(sum[col[x]]==0) change[belong[col[x]]]--;}
inline int read()
{
int x=0,c=1;
char ch=' ';
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
while(ch=='-')c*=-1,ch=getchar();
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x*c;
}
int main()
{
n=read();m=read();
int S=sqrt(n);
for(int i=1;i<=n;i++) a[i]=b[i]=col[i]=read(),belong[i]=(i-1)/S+1;
b[n+1]=-1;b[n+2]=inf;
sort(b+1,b+n+3);
t=unique(b+1,b+n+3)-b-1;
for(int i=1;i<=n;i++) col[i]=lower_bound(b+1,b+t+1,col[i])-b;
for(int i=1;i<=m;i++){
q[i].id=i;
q[i].l=read(),q[i].r=read();
q[i].a=read(),q[i].b=read();
q[i].a=lower_bound(b+1,b+t+1,q[i].a)-b;
q[i].b=upper_bound(b+1,b+t+1,q[i].b)-b-1;
}
for(int i=1;i<=n;i++) if(!L[belong[i]]) L[belong[i]]=i;
for(int i=n;i;i--) if(!R[belong[i]]) R[belong[i]]=i;
sort(q+1,q+m+1,cmp);
int l=1,r=0;
for(int i=1;i<=m;i++){
while(l<q[i].l) del(l++);
while(l>q[i].l) add(--l);
while(r<q[i].r) add(++r);
while(r>q[i].r) del(r--);
if(q[i].a>q[i].b) continue;
if(belong[q[i].a]==belong[q[i].b]){
for(int j=q[i].a;j<=q[i].b;j++) if(sum[j]) q[i].ans1+=sum[j],q[i].ans2++;
continue;
}
for(int j=q[i].a;j<=R[belong[q[i].a]];j++) if(sum[j]) q[i].ans1+=sum[j],q[i].ans2++;
for(int j=belong[q[i].a]+1;j<belong[q[i].b];j++) q[i].ans1+=sumk[j],q[i].ans2+=change[j];
for(int j=L[belong[q[i].b]];j<=q[i].b;j++) if(sum[j]) q[i].ans1+=sum[j],q[i].ans2++;
}
sort(q+1,q+m+1);
for(int i=1;i<=m;i++) printf("%d %d\n", q[i].ans1,q[i].ans2);
}
BZOJ3236: [AHOI2013]作业的更多相关文章
- [bzoj3809]Gty的二逼妹子序列/[bzoj3236][Ahoi2013]作业
[bzoj3809]Gty的二逼妹子序列/[bzoj3236][Ahoi2013]作业 bzoj bzoj 题目大意:一个序列,m个询问在$[l,r]$区间的$[x,y]$范围内的数的个数/种类. ...
- BZOJ3236 [Ahoi2013]作业 【莫队 + 树状数组】
题目链接 BZOJ3236 题解 没想到这题真的是如此暴力 #include<algorithm> #include<iostream> #include<cstring ...
- [BZOJ3236]:[Ahoi2013]作业(莫队+分块)
题目传送门 题目描述 此时已是凌晨两点,刚刚做了$Codeforces$的小$A$掏出了英语试卷.英语作业其实不算多,一个小时刚好可以做完.然后是一个小时可与做完的数学作业,接下来是分别都是一个小时可 ...
- BZOJ3236: [Ahoi2013]作业
Description Input Output Sample Input 3 4 1 2 2 1 2 1 3 1 2 1 1 1 3 1 3 2 3 2 3 Sample Output 2 2 1 ...
- BZOJ3236[Ahoi2013]作业——莫队+树状数组/莫队+分块
题目描述 输入 输出 样例输入 3 4 1 2 2 1 2 1 3 1 2 1 1 1 3 1 3 2 3 2 3 样例输出 2 2 1 1 3 2 2 1 提示 N=100000,M=1000000 ...
- BZOJ3236:[AHOI2013]作业(莫队,分块)
Description Input Output Sample Input 3 4 1 2 2 1 2 1 3 1 2 1 1 1 3 1 3 2 3 2 3 Sample Output 2 2 1 ...
- BZOJ3236: [Ahoi2013]作业 树状数组维护 莫队
水果~~~~ 关于四个while可行性的证明:区间有正确性所以不管那团小东西用没有duang~反它最终总会由于两次覆盖二准确 关于区间种数可行性的证明:他会在0 1间(或两边)来回跳动(过程中),最终 ...
- 【莫队算法】【权值分块】bzoj3236 [Ahoi2013]作业
莫队显然.然后维护转移的时候如果用树状数组,则很容易TLE.所以用权值分块维护转移. 总复杂度O(m*sqrt(n)). #include<cstdio> #include<algo ...
- [BZOJ3236][AHOI2013]作业:树套树/莫队+分块
分析 第一问随便搞,直接说第二问. 令原数列为\(seq\),\(pre_i\)为\(seq_i\)这个值上一个出现的位置,于是可以简化询问条件为: \(l \leq i \leq r\) \(a \ ...
- bzoj3809 Gty的二逼妹子序列 & bzoj3236 [Ahoi2013]作业 莫队+分块
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=3809 https://lydsy.com/JudgeOnline/problem.php?id ...
随机推荐
- 【转】浏览器Request Header和Response Header的内容
1)请求(客户端->服务端[request]) GET(请求的方式) /newcoder/hello.html(请求的目标资源) HTTP/1.1(请求采用的协议和版本号) Ac ...
- QuantStart量化交易文集
Over the last seven years more than 200 quantitative finance articles have been written by members o ...
- mybatis调用oracle存储过程例子.
1.MYBATIS方法: <select id="getFlowNum" statementType="CALLABLE"> <![CDATA ...
- django组件之ContentType
ContentTyep组件: 帮助我们关联所有数据库的表 帮助我们反向查询关联数据表中的所有策略信息 GenericForeignkey(帮助我们快速插入数据) GenericRelation(用于反 ...
- shell_02
if判断: if [$? -eq 0];then echo "xxxxxxxxxxx" else echo "xxxxxxxxxxxxx" fi case判断: ...
- java.util.Calendar
package day14; import com.sun.scenario.effect.impl.sw.sse.SSEBlend_SRC_OUTPeer; import java.util.Cal ...
- Python学习笔记(一)数据类型
一.整型和浮点型 Python可以处理任意大小的整数,当然包括负整数,在程序中的表示方法和数学上的写法一模一样 age=10 num=-35 score=98.8 二.布尔类型 布尔值和布尔代数的表示 ...
- Linux 超级用户和普通用户切换命令
默认登录的是普通用户权限显示$符 tree@ubuntu:/usr$ 从普通用户切换超级用户权限: sudo su tree@ubuntu:/usr$ sudo su 输入密码 [sudo] pass ...
- HTML5游戏开发系列教程5(译)
原文地址:http://www.script-tutorials.com/html5-game-development-lesson-5/ 最终我决定准备下一篇游戏开发系列的文章,我们将继续使用can ...
- PKU 1208 The Blocks Problem(模拟+list应用)
题目大意:原题链接 关键是正确理解题目意思 首先:介绍一下list容器的一些操作:参考链接 list<int> c1; c1.unique(); 去重. c1.r ...