2163: 复杂的大门

Time Limit: 20 Sec  Memory Limit: 259 MB
Submit: 418  Solved: 259
[Submit][Status][Discuss]

Description

你去找某bm玩,到了门口才发现要打开他家的大门不是一件容易的事……
他家的大门外有n个站台,用1到n的正整数编号。你需要对每个站台访问一定次数以后大门才能开启。站台之间有m个单向的传送门,通过传送门到达另一个站台不需要花费任何代价。而如果不通过传送门,你就需要乘坐公共汽车,并花费1单位的钱。值得庆幸的是,任意两个站台之间都有公共汽车直达。
现在给你每个站台必须访问的次数Fi,对于站台i,你必须恰好访问Fi次(不能超过)。
我们用u、v、w三个参数描述一个传送门,表示从站台u到站台v有一个最多可以使用w次的传送门(不一定要使用w次)。值得注意的是,对于任意一对传送门(u1,v1)和(u2,v2),如果有u1<u2,则有v1≤v2;如果有v1<v2,则有u1≤u2;且u1=u2和v1=v2不同时成立。
你可以从任意的站台开始,从任意的站台结束。出发去开始的站台需要花费1单位的钱。你需要求出打开大门最少需要花费多少单位的钱。

Input

第一行包含两个正整数n、m,意义见题目描述。第二行包含n个正整数,第i个数表示Fi。接下来有m行,每行有三个正整数u、v、w,表示从u到v有一个可以使用w次的传送门。

Output

输出一行一个整数,表示打开大门最少花费的钱数。

Sample Input

4 3
5 5 5 5
1 2 1
3 2 1
3 4 1

Sample Output

17

HINT

有20%的数据满足n≤10,m≤50;对于所有的w、Fi,满足1≤w,Fi≤10。有50%的数据满足n≤1000,m≤10000。100%的数据满足1≤n≤10000,1≤m≤100000;对于所有的u、v,满足1≤u,v≤n,u≠v;对于所有的w、Fi,满足1≤w,Fi≤50000。以上的每类数据中都存在50%的数据满足对于所有的w、Fi,有w=Fi=1。

貌似这就是最小路径覆盖的一个点可以被经过多次的版本啊。

最小路径覆盖是要求选尽量少的路径,使得每个点都恰好在一条路径上(也就是路径之间没有交点)。。。。

那么本题就是 要求选尽量少的路径,使得所有点i都满足 i 恰好在 F[i] 条路径上。。。。。

做法是一样的嘛。。。左边一排出点,右边一排入点,因为题目中保证了没有环(那个边的关系就是这个意思),然后Fi的和减去最大流就是答案(也就是会有多少路径起点)

  1. #include<bits/stdc++.h>
  2. #define ll long long
  3. using namespace std;
  4. #define pb push_back
  5. const int maxn=20005;
  6. vector<int> g[maxn];
  7. struct lines{
  8. int to,flow,cap;
  9. }l[maxn*79];
  10. int S,T,t=-1,d[maxn],cur[maxn];
  11. bool v[maxn];
  12.  
  13. inline void add(int from,int to,int cap){
  14. l[++t]=(lines){to,0,cap},g[from].pb(t);
  15. l[++t]=(lines){from,0,0},g[to].pb(t);
  16. }
  17.  
  18. inline bool BFS(){
  19. memset(v,0,sizeof(v)),v[S]=1,d[S]=0;
  20. queue<int> q; q.push(S);
  21. int x; lines e;
  22.  
  23. while(!q.empty()){
  24. x=q.front(),q.pop();
  25. for(int i=g[x].size()-1;i>=0;i--){
  26. e=l[g[x][i]];
  27. if(e.flow<e.cap&&!v[e.to]) v[e.to]=1,d[e.to]=d[x]+1,q.push(e.to);
  28. }
  29. }
  30.  
  31. return v[T];
  32. }
  33.  
  34. int dfs(int x,int A){
  35. if(x==T||!A) return A;
  36. int flow=0,f,sz=g[x].size();
  37.  
  38. for(int &i=cur[x];i<sz;i++){
  39. lines &e=l[g[x][i]];
  40. if(d[x]+1==d[e.to]&&(f=dfs(e.to,min(A,e.cap-e.flow)))){
  41. A-=f,flow+=f;
  42. e.flow+=f,l[g[x][i]^1].flow-=f;
  43. if(!A) break;
  44. }
  45. }
  46.  
  47. return flow;
  48. }
  49.  
  50. inline int max_flow(){
  51. int an=0;
  52.  
  53. while(BFS()){
  54. memset(cur,0,sizeof(cur));
  55. an+=dfs(S,1<<30);
  56. }
  57.  
  58. return an;
  59. }
  60.  
  61. int n,now,tot,m;
  62.  
  63. int main(){
  64. int uu,vv,ww;
  65. scanf("%d%d",&n,&m),S=0,T=(n<<1)|1;
  66. for(int i=1;i<=n;i++) scanf("%d",&now),add(S,i,now),add(i+n,T,now),tot+=now;
  67. for(int i=1;i<=m;i++) scanf("%d%d%d",&uu,&vv,&ww),add(uu,vv+n,ww);
  68.  
  69. printf("%d\n",tot-max_flow());
  70. return 0;
  71. }

bzoj 2163: 复杂的大门的更多相关文章

  1. 【bzoj 2163】复杂的大门(算法效率--拆点+贪心)

    题目:你去找某bm玩,到了门口才发现要打开他家的大门不是一件容易的事-- 他家的大门外有n个站台,用1到n的正整数编号.你需要对每个站台访问一定次数以后大门才能开启.站台之间有m个单向的传送门,通过传 ...

  2. bzoj AC倒序

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

  3. 【BZOJ】【2878】【NOI2012】迷失游乐园

    树形+基环树DP/数学期望 然而我并不会做…… 题解戳这里:http://blog.csdn.net/u011265346/article/details/46328543 好吧先考虑一个简单点的,当 ...

  4. BZOJ 2127: happiness [最小割]

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

  5. BZOJ 3275: Number

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

  6. BZOJ 2879: [Noi2012]美食节

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

  7. bzoj 4610 Ceiling Functi

    bzoj 4610 Ceiling Functi Description bzoj上的描述有问题 给出\(n\)个长度为\(k\)的数列,将每个数列构成一个二叉搜索树,问有多少颗形态不同的树. Inp ...

  8. BZOJ 题目整理

    bzoj 500题纪念 总结一发题目吧,挑几道题整理一下,(方便拖板子) 1039:每条线段与前一条线段之间的长度的比例和夹角不会因平移.旋转.放缩而改变,所以将每条轨迹改为比例和夹角的序列,复制一份 ...

  9. 【sdoi2013】森林 BZOJ 3123

    Input 第一行包含一个正整数testcase,表示当前测试数据的测试点编号.保证1≤testcase≤20. 第二行包含三个整数N,M,T,分别表示节点数.初始边数.操作数.第三行包含N个非负整数 ...

随机推荐

  1. chrome 不支持12px以下字体为题的解决

    现英文9px 设置 在chrome 下无效,可以通过 -webkit-transform: scale(0.75); 12*0.75 =9  得到小字体(在chrome浏览器下 大小缩放到0.75倍) ...

  2. Spring学习-- AOP入门动态代理

    AOP 的拦截功能是由 java 中的动态代理来实现的.说白了,就是在目标类的基础上增加切面逻辑,生成增强的目标类(该切面逻辑或者在目标类函数执行之前,或者目标类函数执行之后,或者在目标类函数抛出异常 ...

  3. canvas知识02:图片放大镜效果

    效果截图: JS代码: <script> // 初始化canvas01和上下文环境 var cav01 = document.getElementById('cav01'); var cx ...

  4. java封装的使用

    一:前言 其实以前我们来学习java特性的时候,对于封装好想觉得没什么用处,至少我那个时候的感觉(不知道是不是我学的太浅薄了~),现在由于项目从零开始做得,在做得过程中我感觉到原来封装是这样用的. 二 ...

  5. mybatis的一些特殊符号标识(大于,小于,等于,不等于)

    特殊字符   替代符号(红色基本为常用的)    &            &      <            <      >            > ...

  6. html初探

    HTML HTML是英文Hyper Text Mark-up Language(超文本标记语言)的缩写,他是一种制作万维网页面标准语言(标记).相当于定义统一的一套规则,大家都来遵守他,这样就可以让浏 ...

  7. bzoj 1002 找规律(基尔霍夫矩阵)

    网上说的是什么基尔霍夫矩阵,没学过这个,打个表找下规律,发现 w[i]=3*w[i-1]-w[i-2]+2; 然后写个高精直接递推就行了 //By BLADEVIL var n :longint; a ...

  8. Linux利用list_head结构实现双向链表

    原文地址:http://www.cnblogs.com/bastard/archive/2012/10/19/2731107.html 通常实现双向链表的数据结构: struct list_node1 ...

  9. WScript.Shell对象的 run()和exec()函数使用详解

    WScript.Shell对象的 run()和exec()函数使用详解 http://blog.sina.com.cn/s/blog_6e14a2050102v47g.html   vbScript ...

  10. Android系统是一个基于BInder通信的C/S架构

    Android系统基本上可以看作是一个基于Binder通信的C/S架构.他有服务器端和客户端.比如自己开发一个程序,肯定是基于Activity的而Activity就是作为客户端,他的服务器端就是Act ...