zoukankan      html  css  js  c++  java
  • Hdu Flow Problem

    View Code
      1 #include <iostream>
      2 #include<cstdio>//最大流SAP
      3 #include<cstring>
      4 #include<vector>
      5 #include<queue>
      6 #include<algorithm>
      7 using namespace std;
      8 #define min(a,b) ((a)<(b))?(a):(b)
      9 #define max(a,b) ((a)>(b))?(a):(b)
     10 #define MAXN 200
     11 #define MAXM 10000+10//M取N的平方倍
     12 #define INF 0x3f3f3f3f
     13 //链式前向星
     14 struct enode
     15 {
     16     int t;
     17     int w;                //权值
     18     int c;                //流量
     19 //  int cost;
     20 //    int pre;            //前向指针
     21     int next;
     22 };
     23 struct lstar
     24 {
     25     struct enode e[MAXM];
     26     int box[MAXN],ecnt;
     27     //int etail[MAXN];        //尾部
     28     void init()
     29     {
     30         ecnt=0;
     31         memset(box,-1,sizeof(box));
     32     //    memset(etail,-1,sizeof(etail));        //初始化尾部
     33     }
     34     void addedge(int f,int t,int c)            //流量重载
     35     {
     36         e[ecnt].next=box[f];
     37         e[ecnt].t=t;
     38         e[ecnt].c=c;
     39         box[f]=ecnt++;
     40         e[ecnt].next=box[t];
     41         e[ecnt].t=f;
     42         e[ecnt].c=0;
     43         box[t]=ecnt++;
     44     }
     45 };
     46 
     47 int sap(int s,int t,lstar G,int N)//最大流问题
     48 {
     49     int gap[MAXN],lvl[MAXN],cur[MAXN],pre[MAXN];
     50     int curflow,ans=0,u,tmp,neck,i;
     51     memset(lvl,0,sizeof(lvl));
     52     memset(gap,0,sizeof(gap));
     53     memset(pre,-1,sizeof(pre));
     54     for(i=0;i<N;i++)
     55         cur[i]=G.box[i];
     56     gap[0]=N;
     57     u=s;
     58     while(lvl[s]<N)
     59     {
     60         if(u==t)
     61         {
     62             curflow=INF;
     63             for(i=s;i!=t;i=G.e[cur[i]].t)
     64             {
     65                 if(curflow>G.e[cur[i]].c)
     66                 {
     67                     neck=i;
     68                     curflow=G.e[cur[i]].c;
     69                 }
     70             }
     71             for(i=s;i!=t;i=G.e[cur[i]].t)
     72             {
     73                 tmp=cur[i];
     74                 G.e[tmp].c-=curflow;
     75                 G.e[tmp^1].c+=curflow;
     76             }
     77             ans+=curflow;
     78             u=neck;
     79         }
     80         for(i=cur[u];i!=-1;i=G.e[i].next)
     81             if(G.e[i].c && lvl[u]==lvl[G.e[i].t]+1)
     82                 break;
     83         if(i!=-1)
     84         {
     85             cur[u]=i;
     86             pre[G.e[i].t]=u;
     87             u=G.e[i].t;
     88         }
     89         else
     90         {
     91             if(--gap[lvl[u]]==0)
     92                 break;
     93              cur[u]=G.box[u];
     94             for(tmp=N,i=G.box[u];i!=-1;i=G.e[i].next)
     95                 if(G.e[i].c)
     96                     tmp=min(tmp,lvl[G.e[i].t]);
     97             lvl[u]=tmp+1;
     98             gap[lvl[u]]++;
     99             if(u!=s)
    100                 u=pre[u];
    101         }
    102     }
    103     return ans;
    104 }
    105 int main()
    106 {
    107       int m,n,t;
    108       lstar  s;
    109       scanf("%d",&t);
    110       int ct=1;
    111         while(t--)
    112         {
    113             int a,b,cost;
    114             cin>>n>>m;
    115            // memset(map,0,sizeof(map));
    116            s.init();
    117            for(int i=0;i<m;i++)
    118             {
    119                cin>>a>>b>>cost;
    120                s.addedge(a-1,b-1,cost);
    121             }//参数含义:源点 汇点 网络结点数量
    122             //printf("####\n");
    123           /*  for(int i=1;i<=n;i++)
    124             {
    125                 for(int k=s.box[i];k!=-1;k=s.e[k].next)
    126                 cout<<i<< " " <<s.e[k].t<< " " <<s.e[k].c<<endl;
    127             }//*/
    128             cout<<"Case "<<ct++<<":";
    129             cout<<" "<<sap(0,n-1,s,n)<<endl;//最大流问题
    130         }
    131     return 0;
    132 }
    133 /*
    134 
    135 2
    136 3 2
    137 1 2 1
    138 2 3 1
    139 3 3
    140 1 2 1
    141 2 3 1
    142 1 3 1
    143 
    144 Case 1: 1
    145 Case 2: 2
    146 
    147 */

    http://acm.hdu.edu.cn/webcontest/contest_showproblem.php?pid=1002&ojid=0&cid=4456&hide=0

    直接求最大流问题

  • 相关阅读:
    20155334 2016-2017-2 《Java程序设计》第四周学习总结
    20155334 2016-2017-2 《Java程序设计》第三周学习总结
    20155334 2016-2017-2 《Java程序设计》第二周学习总结
    20155334 2016-2017-2 《Java程序设计》第一周学习总结
    虚拟机与Linux的初体验
    20155334的第二次随笔
    使用Maven工程
    观察者模式(observer)
    GreenPlum之进程会话管理篇
    Linux下crontab命令添加Kettle作业定时任务
  • 原文地址:https://www.cnblogs.com/someonelikeyou/p/3029743.html
Copyright © 2011-2022 走看看