【BZOJ3876】 [Ahoi2014]支线剧情
Description
Input
Output
输出一行包含一个整数,表示JYY看完所有支线剧情所需要的最少时间。
Sample Input
2 2 1 3 2
2 4 3 5 4
2 5 5 6 6
0
0
0
Sample Output
HINT
JYY需要重新开始3次游戏,加上一开始的一次游戏,4次游戏的进程是
Source
Solution
有上下界费用流。
构图和上下界的网络流类似,不过从新建源到当前节点的费用要设成本来流进来的费用。
Code
- #include <cstdio>
- #include <algorithm>
- #include <cstring>
- #define R register
- #define maxn 310
- #define maxm 23333
- #define inf 0x7fffffff
- #define cmin(_a, _b) (_a > (_b) ? _a = (_b) : 0)
- struct Edge {
- Edge *next, *rev;
- int from, to, cap, cost;
- } *prev[maxn], *last[maxn], e[maxm], *ecnt = e;
- inline void link(R int a, R int b, R int w, R int c)
- {
- // printf("%d %d %d %d\n", a, b, w, c);
- *++ecnt = (Edge) {last[a], ecnt + , a, b, w, c}; last[a] = ecnt;
- *++ecnt = (Edge) {last[b], ecnt - , b, a, , -c}; last[b] = ecnt;
- }
- int s, t, dis[maxn], q[maxn << ], ans, deg[maxn], cs[maxn];
- bool inq[maxn];
- inline bool spfa()
- {
- for (R int i = ; i <= t; ++i) dis[i] = inf;
- R int head = , tail = ; dis[q[] = s] = ;
- while (head < tail)
- {
- R int now = q[++head]; inq[now] = ;
- for (R Edge *iter = last[now]; iter; iter = iter -> next)
- if (iter -> cap && dis[iter -> to] > dis[now] + iter -> cost)
- {
- dis[iter -> to] = dis[now] + iter -> cost;
- prev[iter -> to] = iter;
- !inq[iter -> to] ? inq[q[++tail] = iter -> to] = : ;
- }
- }
- return dis[t] != inf;
- }
- inline void mcmf()
- {
- R int x = inf;
- for (R Edge *iter = prev[t]; iter; iter = prev[iter -> from]) cmin(x, iter -> cap);
- for (R Edge *iter = prev[t]; iter; iter = prev[iter -> from])
- {
- iter -> cap -= x;
- iter -> rev -> cap += x;
- ans += x * iter -> cost;
- }
- }
- int main()
- {
- R int n; scanf("%d", &n);
- s = n + ; t = n + ;
- for (R int i = ; i <= n; ++i)
- {
- R int ni; scanf("%d", &ni);
- for (R int j = ; j <= ni; ++j)
- {
- R int b, c; scanf("%d%d", &b, &c);
- link(i, b, inf, c);
- link(s, b, , c);
- }
- if (ni) link(i, t, ni, );
- if (i != ) link(i, , inf, );
- }
- while (spfa()) mcmf();
- printf("%d\n", ans);
- return ;
- }
【BZOJ3876】 [Ahoi2014]支线剧情的更多相关文章
- bzoj3876: [Ahoi2014]支线剧情
神犇题解:http://blog.csdn.net/popoqqq/article/details/43024221 题意:给定一个DAG,1为起始点,任意一个点可以直接回到1,每条边有经过代价,求一 ...
- [bzoj3876][AHOI2014]支线剧情——上下界费用流
题目 传送门 题解 建立s和t,然后s向1连下限0上限inf费用0的边,除1外所有节点向t连下限0上限inf费用0的边,对于每条边下限为1上限为inf费用为经过费用,然后我们只有做上下界网络流构出新图 ...
- 【BZOJ3876】[Ahoi2014]支线剧情 有上下界费用流
[BZOJ3876][Ahoi2014]支线剧情 Description [故事背景] 宅男JYY非常喜欢玩RPG游戏,比如仙剑,轩辕剑等等.不过JYY喜欢的并不是战斗场景,而是类似电视剧一般的充满恩 ...
- 【BZOJ-3876】支线剧情 有上下界的网络流(有下界有源有汇最小费用最大流)
3876: [Ahoi2014]支线剧情 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 821 Solved: 502[Submit][Status ...
- C++之路进阶——bzoj3876(支线剧情)
F.A.Qs Home Discuss ProblemSet Status Ranklist Contest ModifyUser hyxzc Logout 捐赠本站 Notice:由于本OJ建立在 ...
- bzoj 3876 [Ahoi2014]支线剧情(有上下界的最小费用流)
3876: [Ahoi2014]支线剧情 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 484 Solved: 296[Submit][Status ...
- BZOJ 3876: [Ahoi2014]支线剧情 [上下界费用流]
3876: [Ahoi2014]支线剧情 题意:每次只能从1开始,每条边至少经过一次,有边权,求最小花费 裸上下界费用流...每条边下界为1就行了 注意要加上下界*边权 #include <io ...
- BZOJ 3876: [Ahoi2014]支线剧情 带下界的费用流
3876: [Ahoi2014]支线剧情 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=3876 Description [故事背景] 宅 ...
- [Ahoi2014]支线剧情[无源汇有下界最小费用可行流]
3876: [Ahoi2014]支线剧情 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1538 Solved: 940[Submit][Statu ...
随机推荐
- MAS多媒体的整个存储架构是怎样的?
MAS多媒体的整个存储架构是怎样的?
- 最新的省市编码和sql
下面的项目是整理的最新的省市编码sql文件,可以看看. github
- 高性能异步分布式事务TCC框架(资料汇总)
https://github.com/yu199195/hmily tcc源码解析系列(一)之项目结构 https://yu199195.github.io/2017/10/11/TCC/tcc-on ...
- 教你用 Netty 实现一个简单的 RPC!
众所周知,dubbo 底层使用了 Netty 作为网络通讯框架,而 Netty 的高性能我们之前也分析过源码,对他也算还是比较了解了. 今天我们就自己用 Netty 实现一个简单的 RPC 框架. 1 ...
- numpy数组转置与轴变换
numpy数组转置与轴变换 矩阵的转置 >>> import numpy as np >>> arr=np.arange(15).reshape((3,5)) &g ...
- 虚拟机Vmware-网络配置
非主业,只做简单介绍 虚拟机安装完毕后,需要进行网络配置. 虚拟机有 3 种网络连接方式: 仅主机模式 Host-only:仅支持 虚拟机与宿主机之间进行通信,无法连接外网 桥接模式 bridge:可 ...
- 啥是IOC ?啥是DI ?
1.IOC是什么? IOC (inverse of controll)控制反转:所谓控制反转就是把创建对象(bean),和维护对象(bean)的关系的权利从程序中转移到spring的容器(appl ...
- JS拖拽系列--多元素拖拽,面向对象,es6拖拽
最近不太忙,终于有时间,研究了一下早就想搞定的拖拽系列,先是写了面向过程式的,再做一个面向对象的,再顺便弄弄继承,最后玩一下ES6的class 不觉用了一天多,收获很大.拖拽弄完,想再弄一个拖放. ...
- js实现简繁转换
document.write(" <a name=\"StranLink\" id=\"StranLink\" style=\"col ...
- AIX中的进程管理
1.AIX中的进程 (1)后台进程 后台进程运行时,用户不必等待当前后台进程的结束,即可以运行下一个进程. 后台进程的运行方式: # command & (2)提高进程优先等级 -- ni ...