一棵有根树,每个点有一个音高,有 $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的更多相关文章

  1. 【BZOJ 3681】Arietta

    传送门 题目描述 Arietta 的命运与她的妹妹不同,在她的妹妹已经走进学院的时候,她仍然留在山村中. 但是她从未停止过和恋人 Velding 的书信往来.一天,她准备去探访他. 对着窗外的阳光,临 ...

  2. [BZOJ 3681]Ariettad

    终于是打完了 CH 上的数据结构专场了…… 不过看样子还有一套 5555 传送门: http://ch.ezoj.tk/contest/CH%20Round%20%2351%20-%20Shinrei ...

  3. BZOJ 3681 线段树合并+网络流

    思路: 暴力建图有n*m条边 考虑怎么优化 (那就只能加个线段树了呗) 然后我就不会写了..... 抄了一波题解 //By SiriusRen #include <bits/stdc++.h&g ...

  4. BZOJ3681: Arietta

    题解: 数据结构来优化网络流,貌似都是用一段区间来表示一个点,然后各种乱搞... 发现主席树好吊...在树上建主席树貌似有三种方法: 1.建每个点到根节点这条链上的主席树,可以回答和两点间的路径的XX ...

  5. 【BZOJ-3681】Arietta 网络流 + 线段树合并

    3681: Arietta Time Limit: 20 Sec  Memory Limit: 64 MBSubmit: 182  Solved: 70[Submit][Status][Discuss ...

  6. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  7. BZOJ 2127: happiness [最小割]

    2127: happiness Time Limit: 51 Sec  Memory Limit: 259 MBSubmit: 1815  Solved: 878[Submit][Status][Di ...

  8. BZOJ 3275: Number

    3275: Number Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 874  Solved: 371[Submit][Status][Discus ...

  9. BZOJ 2879: [Noi2012]美食节

    2879: [Noi2012]美食节 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1834  Solved: 969[Submit][Status] ...

随机推荐

  1. echarts3.8.4实现模拟迁移

    动态接受城市的经纬度https://zhidao.baidu.com/question/1384875311724922940.html 调用百度api获得ip对应的城市https://www.cnb ...

  2. 使用新浪IP库获取IP详细地址

    使用新浪IP库获取IP详细地址 <?php class Tool{ /** * 获取IP的归属地( 新浪IP库 ) * * @param $ip String IP地址:112.65.102.1 ...

  3. iOS Xcode 8 打包上架 配置文件问题 此构建版本无效 推送问题 攻克 刚刚 waiting for review

    煎熬...  本来xcode 7 打包正在审核了 还要修改一处购买问题  此时 xcode已经升级到xcode 8 了 升级后 很神奇 应用没报错 很好的运行 (网上很多说xib storyboard ...

  4. python cookboo 文件与IO 函数

    写出文本数据 g = open('test.txt', 'rt', newline='',encoding = 'utf-8', errors='replace') t是windows平台特有的所谓t ...

  5. 04_Apache Hadoop 生态系统

    内容提纲: 1)对 Apache Hadoop 生态系统的认识(Hadoop 1.x 和 Hadoop 2.x) 2) Apache Hadoop 1.x 框架架构原理的初步认识 3) Apache ...

  6. 定制AIX操作系统的shell环境

    操作系统与外部最主要的接口就叫做shell.shell是操作系统最外面的一层.shell管理你与操作系统之间的交互:等待你输入,向操作系统解释你的输入,并且处理各种各样的操作系统的输出结果. shel ...

  7. requestAnimationFrame 的实验性实践

    记得当 requestAnimationFrame 出现时我立马就石更了,就跟初次玩耍 transition 时一样,欣喜若狂... 然后,然后特么的就懵逼了,这明明就是口挖不通的深井呀(如果是我傻, ...

  8. 使用ASP.Net MVC5 Web API OData和Sencha Touch 开发WebAPP

    使用ASP.Net MVC5 Web API OData和SenCha Touch 开发WebAPP Demo 效果 第一步 创建数据库 创建表 第二步 搭建MVC,并导入OData 第三步,写入We ...

  9. CentOS 6.5下Redmine的安装配置

    首先引用百度介绍下redmine: Redmine是用Ruby开发的基于web的项目管理软件,是用ROR框架开发的一套跨平台项目管理系统,据说是源于Basecamp的ror版而来,支持多种数据库,有不 ...

  10. CentOS 6.5 下的截图方法

    1.利用命令模式 捕获整个屏幕 : $ gnome-screenshot 截完屏之后我们可以设置自定义图片存储位置,如图: 捕获当前终端Terminal : $ gnome-screenshot -w ...