博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
洛谷P2469 星际竞速
阅读量:6258 次
发布时间:2019-06-22

本文共 2780 字,大约阅读时间需要 9 分钟。

上下界费用流比较无脑,提供一种更巧妙的费用流,无需上下界。

1 #include 
2 #include
3 #include
4 #include
5 6 const int N = 1610, M = 1000010, INF = 0x3f3f3f3f; 7 8 struct Edge { 9 int nex, v, c, len; 10 }edge[M << 1]; int top = 1; 11 12 int e[N], d[N], vis[N], pre[N], flow[N]; 13 std::queue
Q; 14 15 inline void add(int x, int y, int z, int w) { 16 top++; 17 edge[top].v = y; 18 edge[top].c = z; 19 edge[top].len = w; 20 edge[top].nex = e[x]; 21 e[x] = top; 22 23 top++; 24 edge[top].v = x; 25 edge[top].c = 0; 26 edge[top].len = -w; 27 edge[top].nex = e[y]; 28 e[y] = top; 29 return; 30 } 31 32 inline bool SPFA(int s, int t) { 33 memset(d, 0x3f, sizeof(d)); 34 d[s] = 0; 35 flow[s] = INF; 36 vis[s] = 1; 37 Q.push(s); 38 while(!Q.empty()) { 39 int x = Q.front(); 40 Q.pop(); 41 vis[x] = 0; 42 for(int i = e[x]; i; i = edge[i].nex) { 43 int y = edge[i].v; 44 if(edge[i].c && d[y] > d[x] + edge[i].len) { 45 d[y] = d[x] + edge[i].len; 46 pre[y] = i; 47 flow[y] = std::min(flow[x], edge[i].c); 48 if(!vis[y]) { 49 vis[y] = 1; 50 Q.push(y); 51 } 52 } 53 } 54 } 55 return d[t] < INF; 56 } 57 58 inline void update(int s, int t) { 59 int temp = flow[t]; 60 while(t != s) { 61 int i = pre[t]; 62 edge[i].c -= temp; 63 edge[i ^ 1].c += temp; 64 t = edge[i ^ 1].v; 65 } 66 return; 67 } 68 69 inline int solve(int s, int t, int &cost) { 70 int ans = 0; 71 cost = 0; 72 while(SPFA(s, t)) { 73 ans += flow[t]; 74 cost += flow[t] * d[t]; 75 update(s, t); 76 } 77 return ans; 78 } 79 80 int main() { 81 int n, m; 82 scanf("%d%d", &n, &m); 83 int s = n * 2 + 1; 84 int t = s + 1, S = s + 3, T = s + 4, O = s + 5; 85 for(int i = 1, x; i <= n; i++) { 86 scanf("%d", &x); 87 add(O, i, 1, x); 88 add(i + n, O, INF, 0); 89 // add(i, i + n, 1, 0); 90 add(S, i + n, 1, 0); 91 add(i, T, 1, 0); 92 add(i + n, t, 1, 0); 93 } 94 add(s, O, 1, 0); 95 for(int i = 1, x, y, z; i <= m; i++) { 96 scanf("%d%d%d", &x, &y, &z); 97 if(x > y) { 98 std::swap(x, y); 99 }100 add(x + n, y, INF, z);101 }102 add(t, s, INF, 0);103 104 int ans;105 solve(S, T, ans);106 printf("%d", ans);107 return 0;108 }
上下界费用流AC代码

 

转载于:https://www.cnblogs.com/huyufeifei/p/10116671.html

你可能感兴趣的文章
不用加减乘除实现加法运算
查看>>
django 快速搭建blog
查看>>
矩阵快速幂总结
查看>>
Python 3.5 安装geohash库后import geohash失败
查看>>
基于V4L2的视频驱动开发(1)
查看>>
zoj 1008
查看>>
VC++ CArchive及简单的文件操作方法
查看>>
android中ListView数据混乱问题
查看>>
如何从零安装Mysql
查看>>
Appium简介及工作原理
查看>>
更换笔记本内存:自己动手修电脑(一)
查看>>
区分扫描枪输入和键盘输入的实现
查看>>
【mongdb主从复制和同步】
查看>>
下载文件downloadFile
查看>>
cf-Round542-Div2-B(贪心)
查看>>
日志挖掘(logminer)
查看>>
LaTeX技巧005:定制自己炫酷的章节样式实例
查看>>
1_NAT模式和桥接模式下的网络配置
查看>>
EF架构~为EF DbContext生成的实体添加注释(T5模板应用)
查看>>
【转】VLAN原理详解
查看>>