Description

【故事背景】
宅男JYY非常喜欢玩RPG游戏,比如仙剑,轩辕剑等等。不过JYY喜欢的并不是战斗场景,而是类似电视剧一般的充满恩怨情仇的剧情。这些游戏往往
都有很多的支线剧情,现在JYY想花费最少的时间看完所有的支线剧情。
【问题描述】
JYY现在所玩的RPG游戏中,一共有N个剧情点,由1到N编号,第i个剧情点可以根据JYY的不同的选择,而经过不同的支线剧情,前往Ki种不同的新的剧情点。当然如果为0,则说明i号剧情点是游戏的一个结局了。
JYY观看一个支线剧情需要一定的时间。JYY一开始处在1号剧情点,也就是游戏的开始。显然任何一个剧情点都是从1号剧情点可达的。此外,随着游戏的进行,剧情是不可逆的。所以游戏保证从任意剧情点出发,都不能再回到这个剧情点。由于JYY过度使用修改器,导致游戏的“存档”和“读档”功能损坏了,
所以JYY要想回到之前的剧情点,唯一的方法就是退出当前游戏,并开始新的游戏,也就是回到1号剧情点。JYY可以在任何时刻退出游戏并重新开始。不断开始新的游戏重复观看已经看过的剧情是很痛苦,JYY希望花费最少的时间,看完所有不同的支线剧情。

Input

输入一行包含一个正整数N。
接下来N行,第i行为i号剧情点的信息;
第一个整数为,接下来个整数对,Bij和Tij,表示从剧情点i可以前往剧
情点,并且观看这段支线剧情需要花费的时间。
 

Output

输出一行包含一个整数,表示JYY看完所有支线剧情所需要的最少时间。

 
 
 

Sample Input

6
2 2 1 3 2
2 4 3 5 4
2 5 5 6 6
0
0
0

Sample Output

24

HINT

JYY需要重新开始3次游戏,加上一开始的一次游戏,4次游戏的进程是

1->2->4,1->2->5,1->3->5和1->3->6。
 
对于100%的数据满足N<=300,0<=Ki<=50,1<=Tij<=300,Sigma(Ki)<=5000

Source

By 佚名上传

Solution

有上下界费用流。

构图和上下界的网络流类似,不过从新建源到当前节点的费用要设成本来流进来的费用。

Code

  1. #include <cstdio>
  2. #include <algorithm>
  3. #include <cstring>
  4.  
  5. #define R register
  6. #define maxn 310
  7. #define maxm 23333
  8. #define inf 0x7fffffff
  9. #define cmin(_a, _b) (_a > (_b) ? _a = (_b) : 0)
  10. struct Edge {
  11. Edge *next, *rev;
  12. int from, to, cap, cost;
  13. } *prev[maxn], *last[maxn], e[maxm], *ecnt = e;
  14. inline void link(R int a, R int b, R int w, R int c)
  15. {
  16. // printf("%d %d %d %d\n", a, b, w, c);
  17. *++ecnt = (Edge) {last[a], ecnt + , a, b, w, c}; last[a] = ecnt;
  18. *++ecnt = (Edge) {last[b], ecnt - , b, a, , -c}; last[b] = ecnt;
  19. }
  20. int s, t, dis[maxn], q[maxn << ], ans, deg[maxn], cs[maxn];
  21. bool inq[maxn];
  22. inline bool spfa()
  23. {
  24. for (R int i = ; i <= t; ++i) dis[i] = inf;
  25. R int head = , tail = ; dis[q[] = s] = ;
  26. while (head < tail)
  27. {
  28. R int now = q[++head]; inq[now] = ;
  29. for (R Edge *iter = last[now]; iter; iter = iter -> next)
  30. if (iter -> cap && dis[iter -> to] > dis[now] + iter -> cost)
  31. {
  32. dis[iter -> to] = dis[now] + iter -> cost;
  33. prev[iter -> to] = iter;
  34. !inq[iter -> to] ? inq[q[++tail] = iter -> to] = : ;
  35. }
  36. }
  37. return dis[t] != inf;
  38. }
  39. inline void mcmf()
  40. {
  41. R int x = inf;
  42. for (R Edge *iter = prev[t]; iter; iter = prev[iter -> from]) cmin(x, iter -> cap);
  43. for (R Edge *iter = prev[t]; iter; iter = prev[iter -> from])
  44. {
  45. iter -> cap -= x;
  46. iter -> rev -> cap += x;
  47. ans += x * iter -> cost;
  48. }
  49. }
  50. int main()
  51. {
  52. R int n; scanf("%d", &n);
  53. s = n + ; t = n + ;
  54. for (R int i = ; i <= n; ++i)
  55. {
  56. R int ni; scanf("%d", &ni);
  57. for (R int j = ; j <= ni; ++j)
  58. {
  59. R int b, c; scanf("%d%d", &b, &c);
  60. link(i, b, inf, c);
  61. link(s, b, , c);
  62. }
  63. if (ni) link(i, t, ni, );
  64. if (i != ) link(i, , inf, );
  65. }
  66. while (spfa()) mcmf();
  67. printf("%d\n", ans);
  68. return ;
  69. }

【BZOJ3876】 [Ahoi2014]支线剧情的更多相关文章

  1. bzoj3876: [Ahoi2014]支线剧情

    神犇题解:http://blog.csdn.net/popoqqq/article/details/43024221 题意:给定一个DAG,1为起始点,任意一个点可以直接回到1,每条边有经过代价,求一 ...

  2. [bzoj3876][AHOI2014]支线剧情——上下界费用流

    题目 传送门 题解 建立s和t,然后s向1连下限0上限inf费用0的边,除1外所有节点向t连下限0上限inf费用0的边,对于每条边下限为1上限为inf费用为经过费用,然后我们只有做上下界网络流构出新图 ...

  3. 【BZOJ3876】[Ahoi2014]支线剧情 有上下界费用流

    [BZOJ3876][Ahoi2014]支线剧情 Description [故事背景] 宅男JYY非常喜欢玩RPG游戏,比如仙剑,轩辕剑等等.不过JYY喜欢的并不是战斗场景,而是类似电视剧一般的充满恩 ...

  4. 【BZOJ-3876】支线剧情 有上下界的网络流(有下界有源有汇最小费用最大流)

    3876: [Ahoi2014]支线剧情 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 821  Solved: 502[Submit][Status ...

  5. C++之路进阶——bzoj3876(支线剧情)

    F.A.Qs Home Discuss ProblemSet Status Ranklist Contest ModifyUser  hyxzc Logout 捐赠本站 Notice:由于本OJ建立在 ...

  6. bzoj 3876 [Ahoi2014]支线剧情(有上下界的最小费用流)

    3876: [Ahoi2014]支线剧情 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 484  Solved: 296[Submit][Status ...

  7. BZOJ 3876: [Ahoi2014]支线剧情 [上下界费用流]

    3876: [Ahoi2014]支线剧情 题意:每次只能从1开始,每条边至少经过一次,有边权,求最小花费 裸上下界费用流...每条边下界为1就行了 注意要加上下界*边权 #include <io ...

  8. BZOJ 3876: [Ahoi2014]支线剧情 带下界的费用流

    3876: [Ahoi2014]支线剧情 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=3876 Description [故事背景] 宅 ...

  9. [Ahoi2014]支线剧情[无源汇有下界最小费用可行流]

    3876: [Ahoi2014]支线剧情 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1538  Solved: 940[Submit][Statu ...

随机推荐

  1. MAS多媒体的整个存储架构是怎样的?

    MAS多媒体的整个存储架构是怎样的?

  2. 最新的省市编码和sql

    下面的项目是整理的最新的省市编码sql文件,可以看看. github

  3. 高性能异步分布式事务TCC框架(资料汇总)

    https://github.com/yu199195/hmily tcc源码解析系列(一)之项目结构 https://yu199195.github.io/2017/10/11/TCC/tcc-on ...

  4. 教你用 Netty 实现一个简单的 RPC!

    众所周知,dubbo 底层使用了 Netty 作为网络通讯框架,而 Netty 的高性能我们之前也分析过源码,对他也算还是比较了解了. 今天我们就自己用 Netty 实现一个简单的 RPC 框架. 1 ...

  5. numpy数组转置与轴变换

    numpy数组转置与轴变换 矩阵的转置 >>> import numpy as np >>> arr=np.arange(15).reshape((3,5)) &g ...

  6. 虚拟机Vmware-网络配置

    非主业,只做简单介绍 虚拟机安装完毕后,需要进行网络配置. 虚拟机有 3 种网络连接方式: 仅主机模式 Host-only:仅支持 虚拟机与宿主机之间进行通信,无法连接外网 桥接模式 bridge:可 ...

  7. 啥是IOC ?啥是DI ?

    1.IOC是什么?   IOC (inverse of controll)控制反转:所谓控制反转就是把创建对象(bean),和维护对象(bean)的关系的权利从程序中转移到spring的容器(appl ...

  8. JS拖拽系列--多元素拖拽,面向对象,es6拖拽

    最近不太忙,终于有时间,研究了一下早就想搞定的拖拽系列,先是写了面向过程式的,再做一个面向对象的,再顺便弄弄继承,最后玩一下ES6的class  不觉用了一天多,收获很大.拖拽弄完,想再弄一个拖放. ...

  9. js实现简繁转换

    document.write(" <a name=\"StranLink\" id=\"StranLink\" style=\"col ...

  10. AIX中的进程管理

    1.AIX中的进程 (1)后台进程 后台进程运行时,用户不必等待当前后台进程的结束,即可以运行下一个进程. 后台进程的运行方式: # command &   (2)提高进程优先等级 -- ni ...