【bzoj3089】gty的二逼妹子序列
一眼又是个莫队……
首先看这时间/空间复杂度,线段树/主席树就别想了……
然后么……zcy就有点傻了……
于是zcy看了下hzwer,感觉受教育了。
分块的调块大小真是玄学设计。
有没有一种方法在修改上能够比线段树更快,同时又能相比暴力较快地回答询问呢?
我们可以用分块,把序列分成\(nsqrt(n)块,修改的复杂度是\)O(1)\(,回答询问的复杂度是\)O(nsqrt(n))%
随手写了一发,竟然上去就MLE了……
什么鬼题空间只有28MB……

#include<bits/stdc++.h>
#define inf 1000000007
#define N 1000005
using namespace std;
int n,m,size,cnt,a[100005],ans[1000005];
int rt[100005],L[2010],R[2010],c[100005],cntv[2010];
struct Query{int l,r,a,b,id;}q[1000005];
bool operator<(Query x,Query y){
if(rt[x.l]==rt[y.l])return x.r<y.r;
else return x.l<y.l;
}
int query(int x,int y){
int tmp=0,l=rt[x],r=rt[y];
for(int i=l+1;i<r;i++)tmp+=cntv[i];
if(l==r){for(int i=x;i<=y;i++)if(c[i])++tmp;}
else{
for(int i=x;i<=R[l];i++)if(c[i])++tmp;
for(int i=L[r];i<=y;i++)if(c[i])++tmp;
}
return tmp;
}
inline void del(int x){c[x]--;if(!c[x])cntv[rt[x]]--;}
inline void add(int x){c[x]++;if(c[x]==1)cntv[rt[x]]++;}
void solve(){
int l=1,r=0;
for(int i=1;i<=m;i++){
while(l<q[i].l)del(a[l]),l++;
while(r>q[i].r)del(a[r]),r--;
while(l>q[i].l)l--,add(a[l]);
while(r<q[i].r)r++,add(a[r]);
ans[q[i].id]=query(q[i].a,q[i].b);
}
}
inline int read(){
int f=1,x=0;char ch;
do{ch=getchar();if(ch=='-')f=-1;}while(ch<'0'||ch>'9');
do{x=x*10+ch-'0';ch=getchar();}while(ch>='0'&&ch<='9');
return f*x;
}
int main(){
n=read();m=read();size=(int)sqrt(n/2);
cnt=(n/size)+(n%size!=0);
for(int i=1;i<=n;i++)rt[i]=(i-1)/size+1;
for(int i=1;i<=n;i++){
R[rt[i]]=i;
if(!L[rt[i]])L[rt[i]]=i;
}
for(int i=1;i<=n;i++)a[i]=read();
for(int i=1;i<=m;i++){
q[i].l=read();q[i].r=read();
q[i].a=read();q[i].b=read();
q[i].id=i;
}
sort(q+1,q+m+1);
solve();
for(int i=1;i<=m;i++)printf("%d\n",ans[i]);
return 0;
}
【bzoj3089】gty的二逼妹子序列的更多相关文章
- BZOJ 3809: Gty的二逼妹子序列
3809: Gty的二逼妹子序列 Time Limit: 80 Sec Memory Limit: 28 MBSubmit: 1387 Solved: 400[Submit][Status][Di ...
- 【BZOJ-3809】Gty的二逼妹子序列 分块 + 莫队算法
3809: Gty的二逼妹子序列 Time Limit: 80 Sec Memory Limit: 28 MBSubmit: 1072 Solved: 292[Submit][Status][Di ...
- Bzoj 3809: Gty的二逼妹子序列 莫队,分块
3809: Gty的二逼妹子序列 Time Limit: 35 Sec Memory Limit: 28 MBSubmit: 868 Solved: 234[Submit][Status][Dis ...
- 3809: Gty的二逼妹子序列
3809: Gty的二逼妹子序列 链接 分析: 和这道AHOI2013 作业差不多.权值是1~n的,所以对权值进行分块.$O(1)$修改,$O(\sqrt n)$查询. 代码: #include< ...
- 【BZOJ 3809】 3809: Gty的二逼妹子序列 (莫队+分块)
3809: Gty的二逼妹子序列 Time Limit: 80 Sec Memory Limit: 28 MBSubmit: 1728 Solved: 513 Description Autumn ...
- 【BZOJ3809/3236】Gty的二逼妹子序列 [Ahoi2013]作业 莫队算法+分块
[BZOJ3809]Gty的二逼妹子序列 Description Autumn和Bakser又在研究Gty的妹子序列了!但他们遇到了一个难题. 对于一段妹子们,他们想让你帮忙求出这之内美丽度∈[a,b ...
- [AHOI2013]作业 & Gty的二逼妹子序列 莫队
---题面--- 题解: 题目要求统计一个区间内数值在[a, b]内的数的个数和种数,而这个是可以用树状数组统计出来的,所以可以考虑莫队. 考虑区间[l, r]转移到[l, r + 1],那么对于维护 ...
- [bzoj3809]Gty的二逼妹子序列_莫队_分块
Gty的二逼妹子序列 bzoj-3809 题目大意:给定一个n个正整数的序列,m次询问.每次询问一个区间$l_i$到$r_i$中,权值在$a_i$到$b_i$之间的数有多少个. 注释:$1\le n\ ...
- [bzoj3809]Gty的二逼妹子序列/[bzoj3236][Ahoi2013]作业
[bzoj3809]Gty的二逼妹子序列/[bzoj3236][Ahoi2013]作业 bzoj bzoj 题目大意:一个序列,m个询问在$[l,r]$区间的$[x,y]$范围内的数的个数/种类. ...
- BZOJ3809: Gty的二逼妹子序列
Description Autumn和Bakser又在研究Gty的妹子序列了!但他们遇到了一个难题. 对于一段妹子们,他们想让你帮忙求出这之内美丽度∈[a,b]的妹子的美丽度的种类数. 为了方 ...
随机推荐
- python基础训练营03——字典、集合、判断、循环
一.字典dict: 相比列表list而言,列表list像一本书,如果要查书中的某一个内容,需要把书从前往后翻一遍,直到找到想要获取的东西:而字典dict,就像现实中的字典一样,通过查找特定的字或者词( ...
- 使用PNotify构建消息弹窗
参考地址 官网:http://sciactive.com/pnotify/ GitHub:https://github.com/sciactive/pnotify npm仓库:https://www. ...
- 详解python 局部变量与全局变量
本文将详细分析python的全局变量与局部变量,学过php的人都知道,php里面的全局变量是无法在function里面去使用的,只有超全局变量才可以,那么python会怎么处理全局变量与局部变量呢?下 ...
- unity 归纳
1.获取控件四个角在屏幕上的坐标 Vector3[] corners = new Vector3[]; gameObject.GetComponent<RectTransform>().G ...
- IP数据报格式 及分组转发算法
ip数据报分首部和数据两部分组成: 首部分为固定部分和可变部分 版本——占 4 位,指 IP 协议的版本 目前的 IP 协议版本号为 4 (即 IPv4) 首部长度——占 4 位,可表示的最大数值 是 ...
- lintcode-137-克隆图
137-克隆图 克隆一张无向图,图中的每个节点包含一个 label 和一个列表 neighbors. 数据中如何表示一个无向图?http://www.lintcode.com/help/graph/ ...
- 《学习OpenCV》课后习题解答7
题目:(P105) 创建一个结构,结构中包含一个整数,一个CvPoint和一个 CvRect:称结构体为"my_struct". a. 写两个函数:void Write_my_st ...
- springmvc文件上传,出现400 的错误问题
遇见的原因是公司系统上的图片上传忽然不好使了,报错400.单独针对这个模块调了好长时间都没解决,后来才发现前几天做过一个excel上传导入的功能... 使用SptingMVC3.1.3 对于文件上传提 ...
- 201621123033 《Java程序设计》第14周学习总结
1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结与数据库相关内容. 2. 使用数据库技术改造你的系统 2.1 简述如何使用数据库技术改造你的系统.要建立什么表?截图你的表设计. 2 ...
- Hibernate常用方法之_插入
1.使用session的save方法进行插入 public void saveUser(User user){ Session session = null; Transaction transact ...