[YNOI 2016] 掉进兔子洞
[题目链接]
https://www.lydsy.com/JudgeOnline/problem.php?id=4939
[算法]
不难发现 ,
ansi = (r1 - l1 + 1) + (r2 - l2 + 1) + (r3 - l3 + 1) - sigma(min(cnt1i , cnt2i , cnt3i))
bitset + 莫队即可
时间复杂度 : O(Nsqrt(N) / 32)
[代码]
#include<bits/stdc++.h>
using namespace std;
#define N 100010
#define TT 25000
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull; struct query
{
int l , r;
int id;
} q[N]; int n , m , sz;
int cnt[N] , block[N] , ans[N] , l1[N] , r1[N] , l2[N] , r2[N] , l3[N] , r3[N] , a[N] , b[N];
bool vis[N];
bitset< N > tmp , f[TT + ]; template <typename T> inline void chkmin(T &x , T y) { x = min(x , y); }
template <typename T> inline void chkmax(T &x , T y) { x = max(x , y); }
template <typename T> inline void read(T &x)
{
T f = ; x = ;
char c = getchar();
for (; !isdigit(c); c = getchar()) if (c == '-') f = -f;
for (; isdigit(c); c = getchar()) x = (x << ) + (x << ) + c - '';
x *= f;
}
inline void add(int x)
{
tmp[a[x] + cnt[a[x]]] = ;
++cnt[a[x]];
}
inline void dec(int x)
{
tmp[a[x] + cnt[a[x]] - ] = ;
--cnt[a[x]];
}
inline bool cmp(query a , query b)
{
if (block[a.l] == block[b.l]) return a.r < b.r;
else return a.l < b.l;
}
inline void solve(int l , int r)
{
tmp.reset();
memset(cnt , , sizeof(cnt));
memset(vis , false , sizeof(vis));
int len = ;
for (int i = ; i <= TT; i++) f[i].reset();
for (int i = l; i <= r; i++)
{
q[++len] = (query){l1[i] , r1[i] , i};
ans[i] += r1[i] - l1[i] + ;
q[++len] = (query){l2[i] , r2[i] , i};
ans[i] += r2[i] - l2[i] + ;
q[++len] = (query){l3[i] , r3[i] , i};
ans[i] += r3[i] - l3[i] + ;
}
sort(q + , q + len + , cmp);
int L = q[].l , R = q[].l - ;
for (int i = ; i <= len; i++)
{
while (R < q[i].r)
{
add(R + );
++R;
}
while (R > q[i].r)
{
dec(R);
--R;
}
while (L < q[i].l)
{
dec(L);
++L;
}
while (L > q[i].l)
{
add(L - );
--L;
}
if (!vis[q[i].id - l + ])
{
vis[q[i].id - l + ] = true;
f[q[i].id - l + ] = tmp;
} else f[q[i].id - l + ] &= tmp;
}
for (int i = l; i <= r; i++)
ans[i] -= f[i - l + ].count() * ;
} int main()
{ read(n); read(m);
int size = (int)sqrt(n) + ;
for (int i = ; i <= n; i++) block[i] = (i - ) / size + ;
for (int i = ; i <= n; i++)
{
read(a[i]);
b[i] = a[i];
}
sort(b + , b + n + );
for (int i = ; i <= n; i++) a[i] = lower_bound(b + , b + n + , a[i]) - b;
for (int i = ; i <= m; i++)
{
read(l1[i]); read(r1[i]);
read(l2[i]); read(r2[i]);
read(l3[i]); read(r3[i]); }
for (int i = ; i <= m; i += TT) solve(i , min(i + TT - , m));
for (int i = ; i <= m; i++) printf("%d\n" , ans[i]); return ;
}
[YNOI 2016] 掉进兔子洞的更多相关文章
- [bzoj 4939][Ynoi 2016]掉进兔子洞
传送门 Description 一个长为 n 的序列 a. 有 m 个询问,每次询问三个区间,把三个区间中同时出现的数一个一个删掉,问最后三个区间剩下的数的个数和,询问独立. 注意这里删掉指的是一个一 ...
- luogu P4688 [Ynoi2016]掉进兔子洞 bitset 莫队
题目链接 luogu P4688 [Ynoi2016]掉进兔子洞 题解 莫队维护bitset区间交个数 代码 // luogu-judger-enable-o2 #include<cmath&g ...
- loj #6201. 「YNOI2016」掉进兔子洞
#6201. 「YNOI2016」掉进兔子洞 您正在打galgame,然后突然发现您今天太颓了,于是想写个数据结构题练练手: 给出一个长为 nnn 的序列 aaa. 有 mmm 个询问,每次询问三个区 ...
- YNOI2016:掉进兔子洞 (莫队+bitset)
YNOI2016:掉进兔子洞 题意简述: 有 m 个询问,每次询问三个区间,把三个区间中同时出现的数一个一个删掉,问最后三个区间剩下的数的个数和,询问独立. 注意这里删掉指的是一个一个删,不是把等于这 ...
- [Luogu 4688] [Ynoi2016]掉进兔子洞 (莫队+bitset)
[Luogu 4688] [Ynoi2016]掉进兔子洞 (莫队+bitset) 题面 一个长为 n 的序列 a.有 m 个询问,每次询问三个区间,把三个区间中同时出现的数一个一个删掉,问最后三个区间 ...
- BZOJ.4939.[Ynoi2016]掉进兔子洞(莫队 bitset 分组询问)
BZOJ 洛谷 删掉的数即三个区间数的并,想到bitset:查多个区间的数,想到莫队. 考虑bitset的每一位如何对应每个数的不同出现次数.只要离散化后不去重,每次记录time就可以了. 但是如果对 ...
- 【bzoj4939】【YNOI2016】掉进兔子洞(莫队)
题目描述 您正在打galgame,然后突然发现您今天太颓了,于是想写个数据结构题练练手: 一个长为 n 的序列 a. 有 m 个询问,每次询问三个区间,把三个区间中同时出现的数一个一个删掉,问最后三个 ...
- BZOJ4939: [Ynoi2016]掉进兔子洞(莫队 bitset)
题意 题目链接 一个长为 n 的序列 a. 有 m 个询问,每次询问三个区间,把三个区间中同时出现的数一个一个删掉,问最后三个区间剩下的数的个数和,询问独立. 注意这里删掉指的是一个一个删,不是把等于 ...
- 【洛谷 P4688】 [Ynoi2016]掉进兔子洞(bitset,莫队)
题目链接 第一道Ynoi 显然每次询问的答案为三个区间的长度和减去公共数字个数*3. 如果是公共数字种数的话就能用莫队+bitset存每个区间的状态,然后3个区间按位与就行了. 但现在是个数,bits ...
随机推荐
- Mybatis分页插件-PageHelper的使用
转载:http://blog.csdn.net/u012728960/article/details/50791343 Mybatis分页插件-PageHelper的使用 怎样配置mybatis这里就 ...
- jquery中text(),html(),val()在取值上的区别
1.html():读取和修改一个元素的HTML内容: 2.text():读取和修改一个元素的文本内容: 3.val():读取和修改一个表单元素的value字段值.
- mysql生产环境____主从同步修复案例
一. 硬件环境 Master: Dell R720 Intel(R)Xeon(R) CPU E5-2640 v2 @ 2.00GHz MEM 64G.disk 4*2.5 SAS 网络4* 千兆 ...
- javacript中apply和call的区别
apply:方法能劫持另外一个对象的方法,继承另外一个对象的属性. 接受的参数是一个字符串. call:和apply的意思一样,只不过是参数列表不一样. 接收的参数是一个数组. 例如: <s ...
- 矩形嵌套-记忆化搜索(dp动态规划)
矩形嵌套 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描写叙述 有n个矩形,每个矩形能够用a,b来描写叙述,表示长和宽. 矩形X(a,b)能够嵌套在矩形Y(c,d)中当且仅 ...
- 基于flask做权限控制
和Django实现的原理类似,有时间补充
- qt-mingw530-opencv-开发配置
1.安装好Qt和Qtcreator 2.解压OpenCV源码到一个目录下.路径不能带空格和中文. 3.把E:\Qt\qtcreator-2.1.0\mingw\bin添加到系统环境变量中. 4.安装C ...
- caffe2--Install
Install Welcome to Caffe2! Get started with deep learning today by following the step by step guide ...
- java 回文字符串
package string.string1_5; public class Palindrome { /** * 从两头向中间移动 * @param str * @return */ public ...
- ubuntu 安装后的配置
osx 下用 vmware 安装了一个 ubuntu 虚拟机,版本是 14.04 server.安装完之后要做一系列配置,记录如下. 配置 Android 编译环境 sudo apt-get inst ...