题意:有源汇上下界最小流裸题,主要就是输入要用字符串的问题

  1. #include<bits/stdc++.h>
  2. #define fi first
  3. #define se second
  4. #define mp make_pair
  5. #define pb push_back
  6. #define pii pair<int,int>
  7. #define C 0.5772156649
  8. #define pi acos(-1.0)
  9. #define ll long long
  10. #define mod 1000000007
  11. #define ls l,m,rt<<1
  12. #define rs m+1,r,rt<<1|1
  13.  
  14. using namespace std;
  15.  
  16. const double g=10.0,eps=1e-;
  17. const int N=+,maxn=+,inf=0x3f3f3f3f;
  18.  
  19. struct edge{
  20. int from,to,c,Next,low;
  21. }e[maxn<<];
  22. int cnt,head[N];
  23. int dis[N];
  24. int in[N],out[N];
  25. void add(int u,int v,int c,int low)
  26. {
  27. out[u]+=low;
  28. in[v]+=low;
  29. e[cnt].from=u;
  30. e[cnt].to=v;
  31. e[cnt].c=c;
  32. e[cnt].low=low;
  33. e[cnt].Next=head[u];
  34. head[u]=cnt++;
  35. e[cnt].from=v;
  36. e[cnt].to=u;
  37. e[cnt].c=;
  38. e[cnt].low=low;
  39. e[cnt].Next=head[v];
  40. head[v]=cnt++;
  41. }
  42. bool bfs(int s,int t)
  43. {
  44. memset(dis,-,sizeof dis);
  45. dis[s]=;
  46. queue<int>q;
  47. q.push(s);
  48. while(!q.empty())
  49. {
  50. int x=q.front();
  51. q.pop();
  52. if(x==t)return ;
  53. for(int i=head[x];~i;i=e[i].Next)
  54. {
  55. int te=e[i].to;
  56. if(dis[te]==-&&e[i].c>)
  57. {
  58. dis[te]=dis[x]+;
  59. q.push(te);
  60. }
  61. }
  62. }
  63. return ;
  64. }
  65. int dfs(int x,int mx,int t)
  66. {
  67. if(x==t)return mx;
  68. int flow=;
  69. for(int i=head[x];~i;i=e[i].Next)
  70. {
  71. int te=e[i].to,f;
  72. if(dis[te]==dis[x]+&&e[i].c>&&(f=dfs(te,min(mx-flow,e[i].c),t)))
  73. {
  74. e[i].c-=f;
  75. e[i^].c+=f;
  76. flow+=f;
  77. }
  78. }
  79. if(!flow)dis[x]=-;
  80. return flow;
  81. }
  82. int maxflow(int s,int t)
  83. {
  84. int ans=,f;
  85. while(bfs(s,t))
  86. {
  87. while((f=dfs(s,inf,t)))ans+=f;
  88. }
  89. return ans;
  90. }
  91. void init()
  92. {
  93. cnt=;
  94. memset(head,-,sizeof head);
  95. memset(in,,sizeof in);
  96. memset(out,,sizeof out);
  97. }
  98. int change(string a,int s,int t)
  99. {
  100. if(a=="+")return s;
  101. else if(a=="-")return t;
  102. else
  103. {
  104. int ans=;
  105. for(int i=;i<a.size();i++)
  106. ans=ans*+a[i]-'';
  107. return ans;
  108. }
  109. }
  110. int main()
  111. {
  112. ios::sync_with_stdio(false);
  113. cin.tie();
  114. int n,m;
  115. while(cin>>n>>m)
  116. {
  117. if(!n&&!m)break;
  118. init();
  119. int s=n+m+,t=n+m+;
  120. for(int i=;i<m;i++)
  121. {
  122. string a,b;
  123. int c;
  124. cin>>a>>b>>c;
  125. add(change(a,s,t),change(b,s,t),inf-c,c);
  126. }
  127. int ss=n+m+,tt=n+m+,sum=;
  128. for(int i=;i<=n+m+;i++)
  129. {
  130. if(in[i]>out[i])add(ss,i,in[i]-out[i],),sum+=in[i]-out[i];
  131. else add(i,tt,out[i]-in[i],);
  132. }
  133. int flow=maxflow(ss,tt);
  134. add(t,s,inf,);
  135. flow+=maxflow(ss,tt);
  136. if(flow!=sum)cout<<"impossible"<<endl;
  137. else cout<<e[cnt-].c<<endl;
  138. }
  139. return ;
  140. }
  141. /********************
  142.  
  143. ********************/

hdu3157有源汇上下界最小流的更多相关文章

  1. BZOJ_2502_清理雪道_有源汇上下界最小流

    BZOJ_2502_清理雪道_有源汇上下界最小流 Description        滑雪场坐落在FJ省西北部的若干座山上. 从空中鸟瞰,滑雪场可以看作一个有向无环图,每条弧代表一个斜坡(即雪道), ...

  2. 【Loj117】有源汇上下界最小流(网络流)

    [Loj117]有源汇上下界最小流(网络流) 题面 Loj 题解 还是模板题. #include<iostream> #include<cstdio> #include< ...

  3. BZOJ 2502 清理雪道(有源汇上下界最小流)

    题面 滑雪场坐落在FJ省西北部的若干座山上. 从空中鸟瞰,滑雪场可以看作一个有向无环图,每条弧代表一个斜坡(即雪道),弧的方向代表斜坡下降的方向. 你的团队负责每周定时清理雪道.你们拥有一架直升飞机, ...

  4. BZOJ 2502 清理雪道/ Luogu P4843 清理雪道 (有源汇上下界最小流)

    题意 有一个有向无环图,求最少的路径条数覆盖所有的边 分析 有源汇上下界最小流板题,直接放代码了,不会的看dalao博客:liu_runda 有点长,讲的很好,静心看一定能看懂 CODE #inclu ...

  5. sgu176 有源汇上下界最小流

    题意:有一堆点和边,1起点,n终点,某些边有可能必须满流,要求满足条件的最小流 解法:按原图建边,满流的即上下界都是容量,但是这样按有源汇上下界可行流求出来的可能不是最小流,那么我们需要开始建边的时候 ...

  6. HDU 3157 Crazy Circuits (有源汇上下界最小流)

    题意:一个电路板,上面有N个接线柱(标号1~N)   还有两个电源接线柱  +  - 然后是 给出M个部件正负极的接线柱和最小电流,求一个可以让所有部件正常工作的总电流. 析:这是一个有源汇有上下界的 ...

  7. SGU 176 Flow construction(有源汇上下界最小流)

    Description 176. Flow construction time limit per test: 1 sec. memory limit per test: 4096 KB input: ...

  8. HDU 3157 Crazy Circuits(有源汇上下界最小流)

    HDU 3157 Crazy Circuits 题目链接 题意:一个电路板,上面有N个接线柱(标号1~N),还有两个电源接线柱 + -.给出一些线路,每一个线路有一个下限值求一个能够让全部部件正常工作 ...

  9. bzoj 2502 清理雪道 (有源汇上下界最小流)

    2502: 清理雪道 Time Limit: 10 Sec  Memory Limit: 128 MB Description        滑雪场坐落在FJ省西北部的若干座山上. 从空中鸟瞰,滑雪场 ...

随机推荐

  1. Linux中的服务管理

    RPM包默认安装的服务 查看已安装的服务: chkconfig --list 默认安装位置: /etc/init.d 启动脚本 /etc/sysconfig 初始化环境配置文件 /etc  配置文件位 ...

  2. springboot整合 Thymeleaf模板

    首先引入maven jar依赖 <dependency> <groupId>org.springframework.boot</groupId> <artif ...

  3. BAPI: TRANSACTION_BEGIN的作用

    大概知道是启动一个新会话, CALL FUNCTION 'TRANSACTION_BEGIN' 业务数据处理, CALL FUNCTION 'TRANSACTION_END' 详细功能不清楚. CLE ...

  4. 试着利用BAPI 寻找F-59创建凭证的函数

    功能块代码 F-59开发类 FIBP事务说明 支付请求 事物:FBP1Screen 0BKPF-BLART = AB________________________________________从程 ...

  5. Vuex核心知识(转)

    转:http://www.cnblogs.com/ghost-xyx/p/6380689.html Vuex 是一个专门为 Vue.js 应该程序开发的状态管理模式,它类似于 Redux 应用于 Re ...

  6. 3.7 基于51单片机+MC20的路径显示【使用STC15W内核】

    需要准备的硬件 MC20开发板 1个 https://item.taobao.com/item.htm?id=562661881042 GSM/GPRS天线 1根 https://item.taoba ...

  7. 剑指offer 面试4题

    面试4题: 题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 解题代码一:二 ...

  8. pyhton3 logging模块

    1.简单的将日志打印到屏幕   import logging logging.debug('This is debug message')logging.info('This is info mess ...

  9. pyhton3 sys模块

    Python常用模块之sys sys模块提供了一系列有关Python运行环境的变量和函数. 1 ). sys.stdin 标准输入流.2 ).sys.stdout 标准输出流.3 ). sys.std ...

  10. linux 快速清空文件内容

    Tomcat 的catelina.out 如果不配置按照日期产生会在一个文件中产生大量的输出日志. 清除日志如果直接删除catelina.out将无法输出日志.如果想输出日志只能重启Tomcat才会产 ...