[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 ...
随机推荐
- oralce中相关的概念整理
[数据库名] 概念:就是一个数据库的标识,作用等同于我们的身份证的作用,假设一台机器上安装了多个数据库,那么每一个数据库都会有一个数据库名称相应,这些数据库名称在数据库被创建的时候,数据库名称也会被 ...
- Markdown基础以及个人经验
前言 DFRobot论坛今日支持Markdown发帖了: [md] your content here [/md] 非常棒,再也不怕辛辛苦苦排个版,一夜回到解放前.这里介绍一下Markdown写博客发 ...
- javascript原生调用摄像头
HTML <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta ...
- java内存模型(Java Memory Model)
内容导航: Java内存模型 硬件存储体系结构 Java内存模型和硬件存储体系之间的桥梁: 共享对象的可见性 竞争条件 Java内存模型规定了JVM怎样与计算机存储系统(RAM)协调工作.JVM是一个 ...
- nginx-location rewrite
location 语法 location 有”定位”的意思, 根据Uri来进行不同的定位. 在虚拟主机的配置中,是必不可少的,location可以把网站的不同部分,定位到不同的处理方式上. 比如, 碰 ...
- at android.widget.AbsListView$RecycleBin.addScrapView(AbsListView.java:)
错误提示 错误原因 參考链接 错误提示: at android.widget.AbsListView$RecycleBin.addScrapView(AbsListView.java:) 在Andro ...
- String,StringBuilder性能对照
import java.util.Date; import java.util.UUID; /** * 測试String,StringBuilder性能,推断什么时候改用String,什么时候该用S ...
- 浅谈MySQL外键
http://www.xiaoxiaozi.com/2009/07/12/1158/ 像MySQL这样的关系型数据库管理系统,它们的基础是在数据库的表之间创建关系的能力.通过方便地在不同表中建立记录到 ...
- 每天进步一点点——mysql——Percona XtraBackup(innobackupex)
一. 简单介绍 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对InnoDB和XtraDB存储引擎的数据库非堵塞地备份(对于MyISAM的备份相同须要加表锁).Xt ...
- oracle 的sys 和 system 账号
sys 和 system 账号有啥区别?一直以来懵懵懂懂,只想当然的认为就是权限大小不一样. 但是,它们都是管理员? 现在,我知道有一个区别了: [sys]只能用sysdba身份登录(也许还有syso ...