ZOJ 4053 Couleur

时间:2023-01-23 23:06:52

4053

思路:

主席树

先分别求前缀和后缀的逆序数

然后要求某一段的逆序数,就可以根据前缀或着后缀根据容斥求出答案,

这样需要枚举这一段中的数,求之前或者之后有多少个比他大或比他小的数,

这个可以通过用主席数维护权值线段树来做

然后每次枚举断开后小的那段区间,这样最多需要枚举n*log(n)次

复杂度:n*log(n)*log(n)

代码:

#pragma GCC optimize(2)
#pragma GCC optimize(3)
#pragma GCC optimize(4)
#include<bits/stdc++.h>
using namespace std;
#define fi first
#define se second
#define pi acos(-1.0)
#define LL long long
//#define mp make_pair
#define pb push_back
#define ls rt<<1, l, m
#define rs rt<<1|1, m+1, r
#define ULL unsigned LL
#define pll pair<LL, LL>
#define pii pair<int, int>
#define piii pair<pii, int>
#define mem(a, b) memset(a, b, sizeof(a))
#define fio ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
#define fopen freopen("in.txt", "r", stdin);freopen("out.txt", "w", stout);
//head const int N = 1e5 + , M = 2e6 + ;
int a[N], p[N], root[N], bit[N], lson[M], rson[M], value[M], tot = , n;
LL tmp[N], ans[N], pre[N], suf[N];
multiset<LL> s;
void build(int &x, int l, int r) {
x = ++tot;
if(l == r) {
value[x] = ;
return ;
}
int m = l+r >> ;
build(lson[x], l, m);
build(rson[x], m+, r);
value[x] = value[lson[x]] + value[rson[x]];
}
void update(int old, int &x, int p, int v, int l, int r) {
x = ++tot;
lson[x] = lson[old], rson[x] = rson[old], value[x] = value[old] + v;
if(l == r) return ;
int m = l+r >> ;
if(p <= m) update(lson[x], lson[x], p, v, l, m);
else update(rson[x], rson[x], p, v, m+, r);
}
int query(int L, int R, int x, int l, int r) {
if(L > R) return ;
if(L <= l && r <= R) return value[x];
int m = l+r >> , ans = ;
if(L <= m) ans += query(L, R, lson[x], l, m);
if(R > m) ans += query(L, R, rson[x], m+, r);
return ans;
}
void add(int x, int v) {
while(x <= n+) bit[x] += v, x += x&-x;
}
int sum(int x) {
int ans = ;
while(x) ans += bit[x], x -= x&-x;
return ans;
}
int Find_pre(int pos) {
int l = , r = pos, m = l+r >> ;
while(l < r) {
if(sum(pos) - sum(m-) > ) l = m + ;
else r = m;
m = l+r >> ;
}
return m;
}
int Find_nxt(int pos) {
int l = pos, r = n, m = l+r+ >> ;
while(l < r) {
if(sum(m) - sum(pos-) > ) r = m - ;
else l = m;
m = l+r+ >> ;
}
return m;
}
void solve(int l, int m, int r) {
if(l == r) return ;
else if(l + == r) {
if(l == m) tmp[l] = , s.insert();
else tmp[l-] = , s.insert();
}
else {
if(l == m) {
LL t = tmp[l-];
t -= (query(, a[m]-, root[r], , n) - query(, a[m]-, root[l], , n));
tmp[l] = t;
s.insert(t);
}
else if(r == m) {
LL t = tmp[l-] - (query(a[m]+, n, root[r-], , n) - query(a[m]+, n, root[l-], , n));
tmp[l-] = t;
s.insert(t);
}
else {
LL t = tmp[l-], t1, t2;
if(m-l+ < r-m) {
t1 = pre[m-] - pre[l-];
for (int i = l; i < m; i++) {
t1 -= query(a[i]+, n, root[l-], , n);
} t2 = t - t1;
for (int i = l; i < m; i++) {
t2 -= query(, a[i]-, root[r], , n) - query(, a[i]-, root[m-], , n);
}
t2 -= query(, a[m]-, root[r], , n) - query(, a[m]-, root[m], , n);
}
else {
t2 = suf[m+] - suf[r+];
for (int i = m+; i <= r; i++) {
if(r+ <= n) t2 -= query(, a[i]-, root[n], , n) - query(, a[i]-, root[r], , n);
} t1 = t - t2;
for (int i = m+; i <= r; i++) {
t1 -= query(a[i]+, n, root[m], , n) - query(a[i]+, n, root[l-], , n);
}
t1 -= query(a[m]+, n, root[m-], , n) - query(a[m]+, n, root[l-], , n);
}
tmp[l-] = t1;
tmp[m] = t2;
s.insert(t1);
s.insert(t2);
}
} }
int main() {
int T;
scanf("%d", &T);
while(T--) {
scanf("%d", &n);
for (int i = ; i <= n; i++) scanf("%d", &a[i]);
for (int i = ; i <= n; i++) scanf("%d", &p[i]);
pre[] = suf[n+] = ;
s.clear();
tot = ;
build(root[], , n);
for (int i = ; i <= n; i++) update(root[i-], root[i], a[i], , , n);
for (int i = n; i >= ; i--) {
suf[i] = suf[i+] + query(, a[i]-, root[n], , n) - query(, a[i]-, root[i], , n);
}
for (int i = ; i <= n; i++) {
pre[i] = pre[i-] + query(a[i]+, n, root[i-], , n);
}
for (int i = ; i <= n+; i++) bit[i] = ;
tmp[] = suf[];
s.insert(tmp[]);
for (int i = ; i <= n; i++) {
ans[i] = *s.rbegin();
int t = ans[i]^p[i];
int l = Find_pre(t), r = Find_nxt(t);
s.erase(s.find(tmp[l-]));
solve(l, t, r);
add(t, );
}
for (int i = ; i <= n; i++) printf("%lld%c", ans[i], " \n"[i==n]);
}
return ;
}

ZOJ 4053 Couleur的更多相关文章

  1. Couleur&lpar;启发式 &plus; 主席树&rpar;(终于补坑了)

    ZOJ Problem Set - 4053 Couleur Time Limit: 6 Seconds      Memory Limit: 131072 KB DreamGrid has an a ...

  2. ZOJ People Counting

    第十三届浙江省大学生程序设计竞赛 I 题, 一道模拟题. ZOJ  3944http://www.icpc.moe/onlinejudge/showProblem.do?problemCode=394 ...

  3. ZOJ 3686 A Simple Tree Problem

    A Simple Tree Problem Time Limit: 3 Seconds      Memory Limit: 65536 KB Given a rooted tree, each no ...

  4. ZOJ Problem Set - 1394 Polar Explorer

    这道题目还是简单的,但是自己WA了好几次,总结下: 1.对输入的总结,加上上次ZOJ Problem Set - 1334 Basically Speaking ac代码及总结这道题目的总结 题目要求 ...

  5. ZOJ Problem Set - 1392 The Hardest Problem Ever

    放了一个长长的暑假,可能是这辈子最后一个这么长的暑假了吧,呵呵...今天来实验室了,先找了zoj上面简单的题目练练手直接贴代码了,不解释,就是一道简单的密文转换问题: #include <std ...

  6. ZOJ Problem Set - 1049 I Think I Need a Houseboat

    这道题目说白了是一道平面几何的数学问题,重在理解题目的意思: 题目说,弗雷德想买地盖房养老,但是土地每年会被密西西比河淹掉一部分,而且经调查是以半圆形的方式淹没的,每年淹没50平方英里,以初始水岸线为 ...

  7. ZOJ Problem Set - 1006 Do the Untwist

    今天在ZOJ上做了道很简单的题目是关于加密解密问题的,此题的关键点就在于求余的逆运算: 比如假设都是正整数 A=(B-C)%D 则 B - C = D*n + A 其中 A < D 移项 B = ...

  8. ZOJ Problem Set - 1001 A &plus; B Problem

    ZOJ ACM题集,编译环境VC6.0 #include <stdio.h> int main() { int a,b; while(scanf("%d%d",&amp ...

  9. zoj 1788 Quad Trees

    zoj 1788 先输入初始化MAP ,然后要根据MAP 建立一个四分树,自下而上建立,先建立完整的一棵树,然后根据四个相邻的格 值相同则进行合并,(这又是递归的伟大),逐次向上递归 四分树建立完后, ...

随机推荐

  1. 通过sql server 连接mysql

    图文:通过sql server 连接mysql   1.在SQL SERVER服务器上安装MYSQL ODBC驱动; 驱动下载地址:http://dev.mysql.com/downloads/con ...

  2. CentOS 7 安装 MySQL Database

    CentOS 7 安装 MySQL Database 1. 现在安装包,MySQL的安装包被分成了社区版和企业版,而本文将记录社区版本MySQL安装过程,下载MySQL版本如下: mysql-5.7. ...

  3. innobackupex 重启MySQL

    当重新修改了MySQL的数据目录时: 重启报错: Starting MySQL.The server quit without updating PID file (/[FAILED]l/mysql/ ...

  4. CSharp使用log4net记录日志

    一.先下载log4net.dll.Newtonsoft.Json.dll和配置log4net.config 相关DLL下载地址:log4net相关dll 下载地址:http://logging.apa ...

  5. hdu&lowbar;4826&lowbar;Labyrinth&lowbar;2014百度之星&lpar;dp&rpar;

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=4826 题意:中文题,不解释 题解:dp搞,第一列只能从上往下走,所以先算出第一列的dp数组,然后开两个 ...

  6. postgis常用操作手册

    查询所有函数: SELECT * FROM pg_proc; 更新坐标系st_setsrid,查看坐标系:st_srid 创建空间索引: CREATE INDEX [indexname] ON [ta ...

  7. nfs服务启动失败:Failed to start NFS status monitor for NFSv2&sol;3 locking&period;&period;

    今天碰到个问题,服务器重启后,nfs服务就启动不了了,关闭都关不了.查看系统日志报下面的错: Aug 10 17:08:53 prod-r3-slt-s-01 systemd: Started Pre ...

  8. pam密码策略

    PAM 的使用历史 PAM 是关注如何为服务验证用户的 API.在使用 PAM 之前,诸如 login(和 rlogin.telnet.rsh)之类的应用程序在 /etc/passwd 中查找用户名, ...

  9. ubuntu chrome 安装ubuntu16&period;04 &colon; google浏览器安装及离线插件安装(谷歌访问助手)

    1.https://blog.csdn.net/cheneykl/article/details/79187954 https://download.oracle.com/otn-pub/java/j ...

  10. MXNET:权重衰减

    权重衰减是应对过拟合问题的常用方法. \(L_2\)范数正则化 在深度学习中,我们常使用L2范数正则化,也就是在模型原先损失函数基础上添加L2范数惩罚项,从而得到训练所需要最小化的函数. L2范数惩罚 ...