BZOJ4358: permu(带撤销并查集 不删除莫队)
时间:2022-06-18
本文章向大家介绍BZOJ4358: permu(带撤销并查集 不删除莫队),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
题意
Sol
感觉自己已经老的爬不动了。。
想了一会儿,大概用个不删除莫队+带撤销并查集就能搞了吧,(n sqrt{n} logn)应该卡的过去
不过不删除莫队咋写来着?。。。。跑去学。。
带撤销并查集咋写来着?。。。。跑去学。。。
发现自己的带撤销并查集是错的,,自己yy着调了1h终于过了大数据。。
#include<bits/stdc++.h>
#define Pair pair<int, int>
#define MP(x, y) make_pair(x, y)
#define fi first
#define se second
//#define int long long
#define LL long long
#define Fin(x) {freopen(#x".in","r",stdin);}
#define Fout(x) {freopen(#x".out","w",stdout);}
#define pb(x) push_back(x)
using namespace std;
const int mod = 1e9 + 7;
const int MAXN = 1e6 + 10;
template <typename A, typename B> inline bool chmin(A &a, B b){if(a > b) {a = b; return 1;} return 0;}
template <typename A, typename B> inline bool chmax(A &a, B b){if(a < b) {a = b; return 1;} return 0;}
template <typename A, typename B> inline LL add(A x, B y) {if(x + y < 0) return x + y + mod; return x + y >= mod ? x + y - mod : x + y;}
template <typename A, typename B> inline void add2(A &x, B y) {if(x + y < 0) x = x + y + mod; else x = (x + y >= mod ? x + y - mod : x + y);}
template <typename A, typename B> inline LL mul(A x, B y) {return 1ll * x * y % mod;}
template <typename A, typename B> inline void mul2(A &x, B y) {x = (1ll * x * y % mod + mod) % mod;}
template <typename A> inline void debug(A a){cout << a << 'n';}
template <typename A> inline LL sqr(A x){return 1ll * x * x;}
inline int read() {
char c = getchar(); int x = 0, f = 1;
while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
int N, M, a[MAXN], belong[MAXN], block, ans[MAXN], cnt, fa[MAXN];
struct Q {
int l, r, id;
bool operator < (const Q &rhs) const{
return r < rhs.r;
}
};
vector<Q> q[MAXN];
int SolveBlock(int x, int y) {
if(x == y) return 1;
vector<int> v;
for(int i = x; i <= y; i++) v.pb(a[i]);
sort(v.begin(), v.end());
int res = 1, now = 1;
for(int i = 1; i < v.size(); i++)
now = (v[i] == v[i - 1] + 1 ? now + 1 : 1), chmax(res, now);
return res;
}
int inder[MAXN], Top, ha[MAXN], cur, mx;
struct Node {
int x, deg;
}S[MAXN];
int find(int x) {
return fa[x] == x ? x : find(fa[x]);
}
void unionn(int x, int y) {
x = find(x); y = find(y);
if(x == y) return;
if(inder[x] < inder[y]) swap(x, y);
chmax(mx, inder[x] + inder[y]);
fa[y] = x;
S[++Top] = (Node) {y, inder[y]};
S[++Top] = (Node) {x, inder[x]};//tag
inder[x] += inder[y];
}
void Delet(int cur) {
while(Top > cur) {
Node pre = S[Top--];
fa[pre.x] = pre.x;
inder[pre.x] = pre.deg;
}
}
void Add(int x) {
ha[x] = 1;
if(ha[x - 1]) unionn(x - 1, x);
if(ha[x + 1]) unionn(x, x + 1);
}
void solve(int i, vector<Q> &v) {
memset(ha, 0, sizeof(ha));
Top = 0; int R = min(N, i * block) + 1;
int ql = R, qr = ql - 1;//tag
cur = 0, mx = 1;
for(int i = 1; i <= N; i++) fa[i] = i, inder[i] = 1;
for(int i = 0; i < v.size(); i++) {
Q x = v[i];
while(qr < x.r) Add(a[++qr]);
cur = mx; int pre = Top;
while(ql > x.l) Add(a[--ql]);
ans[x.id] = mx;
mx = cur;
Delet(pre);
while(ql < R) ha[a[ql++]] = 0;
}
}
signed main() {
int mx = 0;
N = read(); M = read(); block = sqrt(N);
for(int i = 1; i <= N; i++) a[i] = read(), belong[i] = (i - 1) / block + 1, chmax(mx, belong[i]);
for(int i = 1; i <= M; i++) {
int x = read(), y = read();
if(belong[x] == belong[y]) ans[i] = SolveBlock(x, y);
else q[belong[x]].push_back({x, y, i});
}
for(int i = 1; i <= mx; i++) sort(q[i].begin(), q[i].end()), solve(i, q[i]);
for(int i = 1; i <= M; i++) printf("%dn", ans[i]);
return 0;
}
/*
8 3
3 1 7 2 4 5 8 6
1 6
1 3
2 4
*/
- hihoCoder #1094 : Lost in the City(枚举,微软苏州校招笔试 12月27日 )
- HDU 2563 统计问题(递归,思维题)
- python接口自动化9-https请求(SSL)
- Windows环境下php开启GD库的方法
- python接口自动化10-token登录
- HDU 1000 A + B Problem(指针版)
- Java 10 已发布!时隔 6 月带来 109 项新特性
- STL中的nth_element()方法的使用
- C++queue容器学习(详解)
- 牛客面经 |这可能不只是一篇面经
- 图的基本算法(BFS和DFS)
- C++STL中set的使用策略(详解)
- Codeforces Round #409 (rated, Div. 2, based on VK Cup 2017 Round 2)(A.思维题,B.思维题)
- 设计模式六大原则(1):单一职责原则
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 0800-5.16.2-如何禁用Hue中Oozie的部分Action
- linux ulimit 调优
- 初识ABP vNext(3):vue对接ABP基本思路
- 0801-什么是Apache Ranger - 4 - Resource vs Tag Based Policies
- IDA-3D技术细节分析
- 0802-Cloudera Data Center7.1.3正式GA
- 2017,科学使用strace神器(附代码,举栗子)
- kubernete编排技术四:Job和CronJob
- Go 视图模板篇(二):模板指令
- go语言学习(五):通道的用法
- PHP无锁内存nosql---Yac的实战
- 0803-什么是Apache Ranger - 5 - Hive Plugin
- 2017年的golang、python、php、c++、c、java、Nodejs性能对比[续]
- go语言学习(四):数组和切片
- 初识ABP vNext(4):vue用户登录&菜单权限