【BZOJ3809/3236】Gty的二逼妹子序列 [Ahoi2013]作业 莫队算法+分块
【BZOJ3809】Gty的二逼妹子序列
Description
Input
Output
对每个询问,单独输出一行,表示sl...sr中权值∈[a,b]的权值的种类数。
Sample Input
4 4 5 1 4 1 5 1 2 1
5 9 1 2
3 4 7 9
4 4 2 5
2 3 4 7
5 10 4 4
3 9 1 1
1 4 5 9
8 9 3 3
2 2 1 6
8 9 1 4
Sample Output
0
0
2
1
1
1
0
1
2
HINT
题解:一看到题第一感觉仍然是莫队+树状数组,但是时间复杂度O(m*sqrt(n)*log(n)),承受不起啊,但是我们可以分块
对于原来的算法,修改时O(m*sqrt(n)*log(n))的,但是查询却是O(m*log(n))的,我们用分块相当于牺牲一点查询的时间,使修改更快一点
言归正传,我们只需要将权值分块,维护每个块内不同权值的种类数以及区间中每个权值的出现次数,然后查询时先查询[a,b]中间的块的种类数,在暴力统计两边的块内的出现次数,于是修改和查询都是O(m*sqrt(n))的了
别忘了特判a,b在一个块内的情况
从1开始的分块真的很别扭啊~
#include <cstdio>
#include <cstring>
#include <iostream>
#include <cmath>
#include <algorithm>
using namespace std;
int n,m,siz;
struct node
{
int qa,qb,ql,qr,org;
}q[1000010];
int v[100010],sk[100010],s[100010],ans[1000010];
int rd()
{
int ret=0; char gc=getchar();
while(gc<'0'||gc>'9') gc=getchar();
while(gc>='0'&&gc<='9') ret=ret*10+gc-'0',gc=getchar();
return ret;
}
bool cmp(node a,node b)
{
if((a.ql-1)/siz==(b.ql-1)/siz) return a.qr<b.qr;
return (a.ql-1)/siz<(b.ql-1)/siz;
}
int main()
{
n=rd(),m=rd();
siz=(int)sqrt((double)n);
int i,j;
for(i=1;i<=n;i++) v[i]=rd();
for(i=1;i<=m;i++) q[i].ql=rd(),q[i].qr=rd(),q[i].qa=rd(),q[i].qb=rd(),q[i].org=i;
sort(q+1,q+m+1,cmp);
int l=1,r=0;
for(i=1;i<=m;i++)
{
while(r<q[i].qr) r++,sk[(v[r]-1)/siz]+=(s[v[r]]==0),s[v[r]]++;
while(r>q[i].qr) s[v[r]]--,sk[(v[r]-1)/siz]-=(s[v[r]]==0),r--;
while(l>q[i].ql) l--,sk[(v[l]-1)/siz]+=(s[v[l]]==0),s[v[l]]++;
while(l<q[i].ql) s[v[l]]--,sk[(v[l]-1)/siz]-=(s[v[l]]==0),l++;
if((q[i].qa-1)/siz==(q[i].qb-1)/siz)
{
for(j=q[i].qa;j<=q[i].qb;j++) ans[q[i].org]+=(s[j]>0);
continue;
}
for(j=q[i].qa;j<=(q[i].qa-1)/siz*siz+siz&&j<=n;j++) ans[q[i].org]+=(s[j]>0);
for(j=(q[i].qb-1)/siz*siz+1;j<=q[i].qb;j++) ans[q[i].org]+=(s[j]>0);
for(j=(q[i].qa-1)/siz+1;j<(q[i].qb-1)/siz;j++) ans[q[i].org]+=sk[j];
}
for(i=1;i<=m;i++) printf("%d\n",ans[i]);
return 0;
}
【BZOJ3236】[Ahoi2013]作业
别的和上题都一样,就是新增一个求[l,r]中数值∈[a,b]的数的个数,这个怎么搞都可以吧~
#include <cstdio>
#include <cstring>
#include <iostream>
#include <cmath>
#include <algorithm>
using namespace std;
int n,m,siz;
struct node
{
int qa,qb,ql,qr,org;
}q[1000010];
int v[100010],sk[100010],sv[100010],s[100010],ans[1000010],sum[1000010];
int rd()
{
int ret=0; char gc=getchar();
while(gc<'0'||gc>'9') gc=getchar();
while(gc>='0'&&gc<='9') ret=ret*10+gc-'0',gc=getchar();
return ret;
}
bool cmp(node a,node b)
{
if((a.ql-1)/siz==(b.ql-1)/siz) return a.qr<b.qr;
return (a.ql-1)/siz<(b.ql-1)/siz;
}
int main()
{
n=rd(),m=rd();
siz=(int)sqrt((double)n);
int i,j;
for(i=1;i<=n;i++) v[i]=rd();
for(i=1;i<=m;i++) q[i].ql=rd(),q[i].qr=rd(),q[i].qa=rd(),q[i].qb=rd(),q[i].org=i;
sort(q+1,q+m+1,cmp);
int l=1,r=0;
for(i=1;i<=m;i++)
{
while(r<q[i].qr) r++,sk[(v[r]-1)/siz]+=(s[v[r]]==0),s[v[r]]++,sv[(v[r]-1)/siz]++;
while(r>q[i].qr) s[v[r]]--,sv[(v[r]-1)/siz]--,sk[(v[r]-1)/siz]-=(s[v[r]]==0),r--;
while(l>q[i].ql) l--,sk[(v[l]-1)/siz]+=(s[v[l]]==0),s[v[l]]++,sv[(v[l]-1)/siz]++;
while(l<q[i].ql) s[v[l]]--,sv[(v[l]-1)/siz]--,sk[(v[l]-1)/siz]-=(s[v[l]]==0),l++;
if((q[i].qa-1)/siz==(q[i].qb-1)/siz)
{
for(j=q[i].qa;j<=q[i].qb;j++) ans[q[i].org]+=(s[j]>0),sum[q[i].org]+=s[j];
continue;
}
for(j=q[i].qa;j<=(q[i].qa-1)/siz*siz+siz&&j<=n;j++) ans[q[i].org]+=(s[j]>0),sum[q[i].org]+=s[j];
for(j=(q[i].qb-1)/siz*siz+1;j<=q[i].qb;j++) ans[q[i].org]+=(s[j]>0),sum[q[i].org]+=s[j];
for(j=(q[i].qa-1)/siz+1;j<(q[i].qb-1)/siz;j++) ans[q[i].org]+=sk[j],sum[q[i].org]+=sv[j];
}
for(i=1;i<=m;i++) printf("%d %d\n",sum[i],ans[i]);
return 0;
}
【BZOJ3809/3236】Gty的二逼妹子序列 [Ahoi2013]作业 莫队算法+分块的更多相关文章
- 【bzoj3809/bzoj3236】Gty的二逼妹子序列/[Ahoi2013]作业 莫队算法+分块
原文地址:http://www.cnblogs.com/GXZlegend/p/6805252.html bzoj3809 题目描述 Autumn和Bakser又在研究Gty的妹子序列了!但他们遇到了 ...
- 【BZOJ-3809】Gty的二逼妹子序列 分块 + 莫队算法
3809: Gty的二逼妹子序列 Time Limit: 80 Sec Memory Limit: 28 MBSubmit: 1072 Solved: 292[Submit][Status][Di ...
- 【bzoj3809】Gty的二逼妹子序列
Description Autumn和Bakser又在研究Gty的妹子序列了!但他们遇到了一个难题. 对于一段妹子们,他们想让你帮忙求出这之内美丽度∈[a,b]的妹子的美丽度的种类数. 为了方便,我们 ...
- 【BZOJ3809】Gty的二逼妹子序列 莫队 分块
题目描述 给你一个长度为\(n\)的数列,还有\(m\)个询问,对于每个询问\((l,r,a,b)\),输出区间\([l,r]\)有多少范围在\([a,b]\)的权值. \(n\leq 100000, ...
- 莫队p2 【bzoj3809】Gty的二逼妹子序列
发现一篇已经够长了...所以就放在这里吧... http://hzwer.com/5749.html ↑依然是看大牛题解过的 袜子那道题太简单了.... 然后被这道题超时卡了一段时间....... ...
- BZOJ3809:Gty的二逼妹子序列
浅谈莫队:https://www.cnblogs.com/AKMer/p/10374756.html 题目传送门:https://lydsy.com/JudgeOnline/problem.php?i ...
- [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]$范围内的数的个数/种类. ...
- BZOJ 3809: Gty的二逼妹子序列
3809: Gty的二逼妹子序列 Time Limit: 80 Sec Memory Limit: 28 MBSubmit: 1387 Solved: 400[Submit][Status][Di ...
随机推荐
- AutoFac文档2(转载)
目录 开始 Registering components 控制范围和生命周期 用模块结构化Autofac xml配置 与.net集成 深入理解Autofac 指导 关于 词汇表 Registering ...
- HttpPutFormContentFilter 和 ContextLoaderListener 讲解
1 ContextLoaderListener 继承自ContextLoader,并且实现ServletContextListener接口. 肯定得实现这个接口了,不然怎么作为Servlet的监听器呢 ...
- FreeMarker中的list集合前后台代码
freemarker中的list集合前后台代码: FreeMarker是一款模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页.电子邮件.配置文件.源代码等)的通用工具. 它 ...
- Apache重启报警,不存在虚拟主机目录(httpd.conf打开了一些扩展)
Apache重启时报警: AH00112: Warning: DocumentRoot [/usr/local/apache/docs/dummy-host.example.com] does not ...
- Linux下磁盘管理命令df与du
Linux下磁盘管理命令df与du 对磁盘进行查看和控制的两个linux命令,df和du. 一.du命令 首先看一下du的help说明: [root@misdwh opt]# du --help ...
- glibc中malloc()的空间overhead
在linux下调用malloc()分配内存的时候,实际占用的内存与请求的内存尺寸的关系是什么呢,这个需要研究一下glibc中malloc()的实现.现在常见linux发行版中带的glibc中采用的都是 ...
- 关于浏览器对静态HTML页面的缓存问题
症状: 刚才为了测试TOMCAT的BASIC安全验证,修改了tomcat-users.xml和/WEB-INF/web.xml之后进行测试,<url-pattern>/*<url-p ...
- 防止js拦截跳转请求的方法
不要直接使用window.open这个方法. 考虑下使用下面这个: openWindow: function(url){ var link = document.createElement('a'); ...
- H2 Database 支持数据类型
整数(INT) -2147483648 到 2147483647 java.lang.Integer 布尔型(BOOLEAN) TRUE 和 FALSE java.lang.Boolean 微整数(T ...
- Webpack实例教程及模块化规范
Webpack 是当下最热门的前端资源模块化管理和打包工具.它能够将很多松散的模块依照依赖和规则打包成符合生产环境部署的前端资源. 通过 loader 的转换,不论什么形式的资源都能够视作模块,比方 ...