zoukankan      html  css  js  c++  java
  • 网络流-费用流模板

    代码中求的是最小费用最大流,求最大费用最大流只需要在设置边权时设置为原权值的相反数,执行一次最小费用最大流,计算得出最小费用的相反数就是要求的最大费用。

    u[x], v[x], w[x], c[x] 分别表示 x 号边的出发点,到达点,权值和残量。

     1 int SPFA()
     2 {
     3     int head, tail, i, node, p;
     4     for (i = 1; i <= ver; ++i) {
     5         dis[i] = INF;
     6         path[i] = 0;
     7         bok[i] = false;
     8     }
     9     dis[s] = 0;
    10     head = tail = 1;
    11     que[tail++] = s;
    12     bok[s] = true;
    13     while (head < tail) {
    14         node = que[head++];
    15         bok[node] = false;
    16         for (p = fst[node]; p; p = nxt[p]) {
    17             if (c[p] <= 0 || dis[node] + w[p] >= dis[v[p]])
    18                 continue;
    19             dis[v[p]] = dis[node] + w[p];
    20             path[v[p]] = p;
    21             if (bok[v[p]])
    22                 continue;
    23             que[tail++] = v[p];
    24             bok[v[p]] = true;
    25         }
    26     }
    27     return dis[t];
    28 }
    29 void modify()
    30 {
    31     int tmp = INF;
    32     for (p = path[t]; p; p = path[u[p]])
    33         tmp = min(c[p], tmp);
    34     cost += tmp * dis[t];
    35     maxflow += tmp;
    36     for (p = path[t]; p; p = path[u[p]]) {
    37         c[p] -= tmp;
    38         c[p + 1] += tmp;
    39     }
    40     return ;
    41 }
    42 
    43 int main()
    44 {
    45     /* input */
    46     while (SPFA() < INF)
    47         modify();
    48     /* now we get 'cost' and 'maxflow' */
    49     return 0;
    50 }
  • 相关阅读:
    Android中ProgressBar显示小数的方法
    Android屏幕适配-安卓切图
    android -services
    Java 位移运算符
    异常、集合、数据结构
    常用类
    编码
    String类
    Android-1
    ButterKnife注解式绑定控件
  • 原文地址:https://www.cnblogs.com/ghcred/p/7148214.html
Copyright © 2011-2022 走看看