[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 ...
随机推荐
- Mingw/Code::Block/wxWidgets 搭建
Mingw The MinGW project maintains and distributes a number of different core components and suppleme ...
- Direct2D教程(一)Direct2D已经来了,谁是GDI的终结者?
什么是Direct2D 一言以蔽之,就是Windows 7平台上的一个2D图形API,可以提供高性能,高质量的2D渲染.大多数人对Direct2D可能都比较陌生,以至于我之前在论坛上提到这个词的时候, ...
- 老司机找bug的十年心路历程
一.码畜:靠编译器帮自己查语法错误 消灭笔误:编写适合程序猿的键盘练习 if (常量==变量或表达式) 使用goto接力超长的if,switch 连续的if还是if elseif 多个条件的组合:精心 ...
- IntelliJ IDEA 10.5.1 引用外部Jar包
具体步骤: File -> Project Structure (ctrl + shift + alt + s ) -> Module -> Dependencies -> A ...
- CentOS6.5_64bit下编译安装MySQL-5.6.23
转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/44785511 ************************************** ...
- SpringMVC:走通一个SpringMVC
我们现在使用SpringMVC来做一个小的用户管理系统,由于重点在学习SpringMVC,这里我们就不用数据库了. 该小系统实现的功能是:1.登录,不做用户名密码的正确性判断,任何用户名+密码都可以成 ...
- Java获取本机MAC地址[转]
原文地址:https://www.cnblogs.com/hxsyl/p/3422191.html Java获取本机MAC地址 为什么写这个呢?因为前几天看见网上有采用windows命令获取局域网 ...
- Python生成器定义
通过列表生成式,我们可以直接创建一个列表.但是,受到内存限制,列表容量肯定是有限的.而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几个元素,那后面绝大多数元素 ...
- Swift的两个小窍门
一:查看Swift版本号(How do I see which version of Swift I’m using in Xcode?) 终端下输入:xcrun swift -version(in ...
- Nexus 5更新 Android5.0 失败解决方法
Android 5.0最终推出了正式版,今天也及时刷到了Android5.0 (LRX21O),官方链接:https://developers.google.com/android/nexus/ima ...