【bzoj3809/bzoj3236】Gty的二逼妹子序列/[Ahoi2013]作业 莫队算法+分块
原文地址:http://www.cnblogs.com/GXZlegend/p/6805252.html
bzoj3809
题目描述
输入
输出
对每个询问,单独输出一行,表示sl...sr中权值∈[a,b]的权值的种类数。
样例输入
10 10
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
样例输出
2
0
0
2
1
1
1
0
1
2
bzoj3236
题目描述
同上,只是多求了一个大小在[a,b]范围内数的个数(非数的种类数,即可以重复计算)
题解
莫队算法+分块,几乎是双倍经验
一个很显然的方法是莫队算法+树状数组,然而修改次数为n√n,修改时间为O(logn),会TLE。
由于查询次数比较少,所以可以想办法将修改时间减少,相应的增加查询时间。
这可以使用分块。
将美丽度(权值)分块,并记录每块中权值的种类数,这样在查询时只需要先找中间的块,再暴力找两边即可。
修改总时间复杂度为O(n√n*1),查询总时间复杂度为O(n*√n)。
注意查询时对两端在同一块中的特判。
对于bzoj3236,数的个数同样可以分块来求,而且相比求数的种类数更简单。
bzoj3809:
#include <cstdio>
#include <cmath>
#include <algorithm>
using namespace std;
struct data
{
int l , r , x , y , id;
}a[1000010];
int v[100010] , cnt[100010] , num[410] , si , ans[1000010];
bool cmp(data a , data b)
{
return (a.l - 1) / si == (b.l - 1) / si ? a.r < b.r : (a.l - 1) / si < (b.l - 1) / si;
}
int main()
{
int n , m , i , j , lp = 1 , rp = 0;
scanf("%d%d" , &n , &m) , si = (int)sqrt(n);
for(i = 1 ; i <= n ; i ++ ) scanf("%d" , &v[i]);
for(i = 1 ; i <= m ; i ++ ) scanf("%d%d%d%d" , &a[i].l , &a[i].r , &a[i].x , &a[i].y) , a[i].id = i;
sort(a + 1 , a + m + 1 , cmp);
for(i = 1 ; i <= m ; i ++ )
{
while(lp > a[i].l) lp -- , num[(v[lp] - 1) / si] += (!cnt[v[lp]]) , cnt[v[lp]] ++ ;
while(rp < a[i].r) rp ++ , num[(v[rp] - 1) / si] += (!cnt[v[rp]]) , cnt[v[rp]] ++ ;
while(lp < a[i].l) cnt[v[lp]] -- , num[(v[lp] - 1) / si] -= (!cnt[v[lp]]) , lp ++ ;
while(rp > a[i].r) cnt[v[rp]] -- , num[(v[rp] - 1) / si] -= (!cnt[v[rp]]) , rp -- ;
if((a[i].x - 1) / si == (a[i].y - 1) / si)
for(j = a[i].x ; j <= a[i].y ; j ++ )
ans[a[i].id] += (cnt[j] > 0);
else
{
for(j = (a[i].x - 1) / si + 1 ; j < (a[i].y - 1) / si ; j ++ ) ans[a[i].id] += num[j];
for(j = a[i].x ; j <= ((a[i].x - 1) / si + 1) * si ; j ++ ) ans[a[i].id] += (cnt[j] > 0);
for(j = (a[i].y - 1) / si * si + 1 ; j <= a[i].y ; j ++ ) ans[a[i].id] += (cnt[j] > 0);
}
}
for(i = 1 ; i <= m ; i ++ ) printf("%d\n" , ans[i]);
return 0;
}
bzoj3236,可以看到只有极小部分改动:
#include <cstdio>
#include <cmath>
#include <algorithm>
using namespace std;
struct data
{
int l , r , x , y , id;
}a[1000010];
int v[100010] , cnt[100010] , num[410] , sum[401] , si , ans1[1000010] , ans2[1000010];
bool cmp(data a , data b)
{
return (a.l - 1) / si == (b.l - 1) / si ? a.r < b.r : (a.l - 1) / si < (b.l - 1) / si;
}
int main()
{
int n , m , i , j , lp = 1 , rp = 0;
scanf("%d%d" , &n , &m) , si = (int)sqrt(n);
for(i = 1 ; i <= n ; i ++ ) scanf("%d" , &v[i]);
for(i = 1 ; i <= m ; i ++ ) scanf("%d%d%d%d" , &a[i].l , &a[i].r , &a[i].x , &a[i].y) , a[i].id = i;
sort(a + 1 , a + m + 1 , cmp);
for(i = 1 ; i <= m ; i ++ )
{
while(lp > a[i].l) lp -- , num[(v[lp] - 1) / si] += (!cnt[v[lp]]) , sum[(v[lp] - 1) / si] ++ , cnt[v[lp]] ++ ;
while(rp < a[i].r) rp ++ , num[(v[rp] - 1) / si] += (!cnt[v[rp]]) , sum[(v[rp] - 1) / si] ++ , cnt[v[rp]] ++ ;
while(lp < a[i].l) cnt[v[lp]] -- , num[(v[lp] - 1) / si] -= (!cnt[v[lp]]) , sum[(v[lp] - 1) / si] -- , lp ++ ;
while(rp > a[i].r) cnt[v[rp]] -- , num[(v[rp] - 1) / si] -= (!cnt[v[rp]]) , sum[(v[rp] - 1) / si] -- , rp -- ;
if((a[i].x - 1) / si == (a[i].y - 1) / si)
for(j = a[i].x ; j <= a[i].y ; j ++ )
ans1[a[i].id] += cnt[j] , ans2[a[i].id] += (cnt[j] > 0);
else
{
for(j = (a[i].x - 1) / si + 1 ; j < (a[i].y - 1) / si ; j ++ ) ans1[a[i].id] += sum[j] , ans2[a[i].id] += num[j];
for(j = a[i].x ; j <= ((a[i].x - 1) / si + 1) * si ; j ++ ) ans1[a[i].id] += cnt[j] , ans2[a[i].id] += (cnt[j] > 0);
for(j = (a[i].y - 1) / si * si + 1 ; j <= a[i].y ; j ++ ) ans1[a[i].id] += cnt[j] , ans2[a[i].id] += (cnt[j] > 0);
}
}
for(i = 1 ; i <= m ; i ++ ) printf("%d %d\n" , ans1[i] , ans2[i]);
return 0;
}
【bzoj3809/bzoj3236】Gty的二逼妹子序列/[Ahoi2013]作业 莫队算法+分块的更多相关文章
- 【BZOJ3809/3236】Gty的二逼妹子序列 [Ahoi2013]作业 莫队算法+分块
[BZOJ3809]Gty的二逼妹子序列 Description Autumn和Bakser又在研究Gty的妹子序列了!但他们遇到了一个难题. 对于一段妹子们,他们想让你帮忙求出这之内美丽度∈[a,b ...
- 【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的二逼妹子序列/[bzoj3236][Ahoi2013]作业
[bzoj3809]Gty的二逼妹子序列/[bzoj3236][Ahoi2013]作业 bzoj bzoj 题目大意:一个序列,m个询问在$[l,r]$区间的$[x,y]$范围内的数的个数/种类. ...
- [bzoj3809]Gty的二逼妹子序列_莫队_分块
Gty的二逼妹子序列 bzoj-3809 题目大意:给定一个n个正整数的序列,m次询问.每次询问一个区间$l_i$到$r_i$中,权值在$a_i$到$b_i$之间的数有多少个. 注释:$1\le n\ ...
- BZOJ 3809: Gty的二逼妹子序列
3809: Gty的二逼妹子序列 Time Limit: 80 Sec Memory Limit: 28 MBSubmit: 1387 Solved: 400[Submit][Status][Di ...
随机推荐
- jQuery选择器与事件学习笔记
层次选择器: $("div li")获取div下的所有li元素(后代.子.子的子......) $("div>li")获取div下的直接li子元素. ...
- v-if
vue中通过v-if,v-else-if,v-else的对应的Boolean值来操作元素在dom中是否移除. 这里就以单纯的true,false来模拟一下.注:标签属性去出来的值为string类型. ...
- BZOJ3669: [Noi2014]魔法森林(瓶颈生成树 LCT)
Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 3558 Solved: 2283[Submit][Status][Discuss] Descript ...
- dts--framework(二)
Framwork下个文件中包含的函数 packet.py LayersTypes = { ', 'arp', 'lldp'], # ipv4_ext_unknown, ipv6_ext_unknown ...
- django中的分页管理
有时,展示的对象太多,需要对他们进行分页展示,不能一页把所有的结果都展示出来吧,那样的话,哈哈,挺逗 使用Django分页器功能 从Django中导入Paginator模块(没有的话,自行下载,我是w ...
- C# 打开帮助文档,打开电脑中其他应用或者文件
打开帮助文档 System.Diagnostics.Process.Start(Directory.GetCurrentDirectory() + "\\" + "hel ...
- 设置默认以管理员运行的WinForm
右键工程名, 属性; 选择"安全性"; 勾选"启用ClickOnce安全设置"与"这是完全可信的应用程序"; 退出该页面, app.mani ...
- 通过Aspose.Word和ZXING生成复杂的WORD表格
1.前言 这是我之前做的一个项目中要求的功能模块,它的需求是生成一个WORD文档,需要每页一个表格并且表格中需要插入文字.条形码和二维码等信息,页数可控制.具体的效果如下图所示: 可以看到有以下几点是 ...
- 关于我的Android 博客
我是曹新雨,我为自己代言.现在的菜鸟,3年以后我就是大神.为自己加油.微信:aycaoxinyu 关于我的Android博客,都是我当初遇到困难,克服之后,写上去的.后来,有人加我微信,问我一些问题, ...
- Java基本数据类型总结二
Java 基本数据类型总结二 变量就是申请内存来存储值.也就是说,当创建变量的时候,需要在内存中申请空间. 内存管理系统根据变量的类型为变量分配存储空间,分配的空间只能用来储存该类型数据. 因此,通过 ...