bzoj 3681 Arietta
一棵有根树,每个点有一个音高,有 $m$ 中弹奏方法,每种方法可以弹奏 $d$ 子树中音高在 $[l,r]$ 间的音符,每种方法最多弹 $t$ 次
求最多能弹出多少个音符
$n \leq 10000$
sol:
网络流
暴力连边是
1. $S \rightarrow 每个点$
2. $每个方法 \rightarrow T$
3. $每个点 \rightarrow 每个能用到的方法$
第一种边限制是 $1$ ,第二种边限制是 $t$,第三种边没有限制
第一第二种不好优化,考虑优化第三种
第三种本质上是对树上 $dfn$ 是一段区间(子树),权值也是一段区间的点连边
考虑数据结构优化
可以使用可持久化线段树合并
一开始每个点向它所在的线段树上的点连边
每次合并的时候原来的点向合并出来的新点连边
对于方法我们把它能作用的区域向它连边
这样边数是 $O(2n) + O(可持久化线段树)$ 的,大概是 $O(nlogn)$
#include <bits/stdc++.h>
#define LL long long
#define rep(i, s, t) for (register int i = (s), i##end = (t); i <= i##end; ++i)
#define dwn(i, s, t) for (register int i = (s), i##end = (t); i >= i##end; --i)
using namespace std;
inline int read() {
int x = , f = ; char ch;
for (ch = getchar(); !isdigit(ch); ch = getchar()) if (ch == '-') f = -f;
for (; isdigit(ch); ch = getchar()) x = * x + ch - '';
return x * f;
}
const int maxn = , maxm = , inf = ;
struct Dinic {
int cur[maxm], head[maxm], nx[maxm];
int n, m, s, t;
struct Edge {
int from, to, caps;
Edge(){}
Edge(int _1, int _2, int _3): from(_1), to(_2), caps(_3) {}
}es[maxm];
void AddEdge(int u, int v, int w) {
es[m] = Edge(u, v, w); nx[m] = head[u]; head[u] = m++;
es[m] = Edge(v, u, ); nx[m] = head[v]; head[v] = m++;
}
void setn(int _) {n = _;}
Dinic() {m = ; memset(head, -, sizeof(head));}
queue<int> q; int dis[maxn];
bool BFS() {
rep(i, , n) dis[i] = ;
q.push(t); dis[t] = ;
while(!q.empty()) {
int now = q.front(); q.pop();
for(int i=head[now];~i;i=nx[i]) {
Edge &e = es[i^];
if(!dis[e.from] && e.caps) {
dis[e.from] = dis[now] + ;
q.push(e.from);
}
}
}
return (dis[s] > );
}
int DFS(int u, int a) {
if(u == t || !a) return a;
int flow = , f;
for(int &i = cur[u]; ~i; i = nx[i]) {
Edge &e = es[i];
if(dis[e.to] == dis[u] - && (f = DFS(e.to, min(e.caps, a)))) {
e.caps -= f; es[i^].caps += f;
a -= f; flow += f;
if(!a) return flow;
}
}
return flow;
}
int MaxFlow(int _s, int _t) {
s = _s, t = _t; int res = ;
while(BFS()) {
memcpy(cur, head, (n + ) * sizeof(int));
res += DFS(s, );
}
return res;
}
} sol;
int s, t, nodes;
struct Ques {
int l, r, d, t;
Ques(){}
Ques(int _1, int _2, int _3, int _4) : l(_1), r(_2), d(_3), t(_4) {}
}qs[maxn];
int n, m;
int fa[maxn], h[maxn];
int first[maxn], nx[maxn], to[maxn], cnt;
inline void add(int u, int v) {
to[++cnt] = v;
nx[cnt] = first[u];
first[u] = cnt;
}
int root[maxn], ls[maxm << ], rs[maxm << ], dfn;
inline void Insert(int &x, int l, int r, int pos, int p) {
x = ++dfn;
if(l == r) {
sol.AddEdge(p, x + nodes, inf);
return;
}
int mid = (l + r) >> ;
if(pos <= mid) Insert(ls[x], l, mid, pos, p) ;
else Insert(rs[x], mid + , r, pos, p) ;
if(ls[x]) sol.AddEdge(ls[x] + nodes, x + nodes, inf);
if(rs[x]) sol.AddEdge(rs[x] + nodes, x + nodes, inf);
}
inline int merge(int x, int y, int l, int r) {
if(!x || !y) return x + y;
int z = ++dfn;
if(l == r) {
sol.AddEdge(x + nodes, z + nodes, inf);
sol.AddEdge(y + nodes, z + nodes, inf);
return z;
}
int mid = (l + r) >> ;
ls[z] = merge(ls[x], ls[y], l, mid);
rs[z] = merge(rs[x], rs[y], mid+, r);
if(ls[z]) sol.AddEdge(ls[z] + nodes, z + nodes, inf);
if(rs[z]) sol.AddEdge(rs[z] + nodes, z + nodes, inf);
return z;
}
inline void link(int x, int l, int r, int L, int R, int p) {
if(!x) return;
if(L <= l && r <= R) {
sol.AddEdge(x + nodes, p, inf);
return;
}
int mid = (l + r) >> ;
if(L <= mid) link(ls[x], l, mid, L, R, p);
if(R > mid) link(rs[x], mid+, r, L, R, p);
}
inline void dfs(int x) {
Insert(root[x], , n, h[x], x);
for(int i=first[x];i;i=nx[i]) {
dfs(to[i]);
root[x] = merge(root[x], root[to[i]], , n);
}
} int main() {
n = read(), m = read();
s = n + m + , t = n + m + , nodes = t + ;
rep(i, , n) {
fa[i] = read();
add(fa[i], i);
}
rep(i, , n) {
h[i] = read();
sol.AddEdge(s, i, );
} dfs();
rep(i, , m) {
int l = read(), r = read(), d = read(), ct = read();
link(root[d], , n, l, r, i+n);
qs[i] = Ques(l, r, d, ct); sol.AddEdge(i + n, t, ct);
}
sol.setn(nodes + dfn + );
cout << sol.MaxFlow(s, t) << endl;
}
bzoj 3681 Arietta的更多相关文章
- 【BZOJ 3681】Arietta
传送门 题目描述 Arietta 的命运与她的妹妹不同,在她的妹妹已经走进学院的时候,她仍然留在山村中. 但是她从未停止过和恋人 Velding 的书信往来.一天,她准备去探访他. 对着窗外的阳光,临 ...
- [BZOJ 3681]Ariettad
终于是打完了 CH 上的数据结构专场了…… 不过看样子还有一套 5555 传送门: http://ch.ezoj.tk/contest/CH%20Round%20%2351%20-%20Shinrei ...
- BZOJ 3681 线段树合并+网络流
思路: 暴力建图有n*m条边 考虑怎么优化 (那就只能加个线段树了呗) 然后我就不会写了..... 抄了一波题解 //By SiriusRen #include <bits/stdc++.h&g ...
- BZOJ3681: Arietta
题解: 数据结构来优化网络流,貌似都是用一段区间来表示一个点,然后各种乱搞... 发现主席树好吊...在树上建主席树貌似有三种方法: 1.建每个点到根节点这条链上的主席树,可以回答和两点间的路径的XX ...
- 【BZOJ-3681】Arietta 网络流 + 线段树合并
3681: Arietta Time Limit: 20 Sec Memory Limit: 64 MBSubmit: 182 Solved: 70[Submit][Status][Discuss ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- BZOJ 2127: happiness [最小割]
2127: happiness Time Limit: 51 Sec Memory Limit: 259 MBSubmit: 1815 Solved: 878[Submit][Status][Di ...
- BZOJ 3275: Number
3275: Number Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 874 Solved: 371[Submit][Status][Discus ...
- BZOJ 2879: [Noi2012]美食节
2879: [Noi2012]美食节 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1834 Solved: 969[Submit][Status] ...
随机推荐
- val() attr('value')
val() 只能更改输入框内的值,能更改value属性, 在浏览器中体现不出value被改变 attr('value') 都可以 谷歌浏览器 val,attr都能获取输入框最新的value值
- PAT 天梯赛 L1-009. N个数求和 【模拟】
题目链接 https://www.patest.cn/contests/gplt/L1-009 思路 每一步每一步 往上加,但是要考虑 溢出,所以用 LONG LONG 而且 每一步 都要约分 才能保 ...
- 每天一个Linux命令(49)traceroute命令
traceroute指令让你追踪网络数据包的路由途径,预设数据包大小是40Bytes. (1)用法: 用法: traceroute [参数] [主机] (2)功能: ...
- centos磁盘安装与磁盘分区方案
概述 关于centos分区的相关知识 无论怎么分区并不会影响系统文件目录的布局,如果只分/和swap这两个区 没有 usr , var , etc 等分区,在安装好后文件根目录里依然会有usr , v ...
- 在shell,R,python中用变量和常量创建文件名
很多时候我们希望文件名的格式是:变量+常量的. 1.shell:变量"常量" [wangjq@mgmt multi_pcr]$ a="var" [wangjq@ ...
- python爬虫之urllib库
请求库 urllib urllib主要分为几个部分 urllib.request 发送请求urllib.error 处理请求过程中出现的异常urllib.parse 处理urlurllib.robot ...
- Eclipse开发快捷键精选
1.alt+?或alt+/:自动补全代码或者提示代码2.ctrl+o:快速outline视图3.ctrl+shift+r:打开资源列表4.ctrl+shift+f:格式化代码5.ctrl+e:快速转换 ...
- FreeBSD 安装过程
FreeBSD安装步骤: 回车 按默认回车 输入服务器的计算机名 去掉games,加上src安装如下图 Lib32 ports src这三项一定要安装上 回车 选择Manual 进入以后点create ...
- SpringCloud-路由网关(Zuul)
在微服务架构中,需要几个基础的服务治理组件,包括服务注册与发现.服务消费.负载均衡.断路器.只能路由.配置管理等,由这几个基础组件相互协作,共同组建了一个简单的微服务系统. 在Spring Cloud ...
- JavaScript -- 练习 window 流氓广告
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...