POJ 1087 —— A Plug for UNIX

2361 단어 네트워크 흐름
원제:http://poj.org/problem?id=1087
제목: n 개의 콘센트, m 개의 전기 와 그 에 대응 하 는 콘센트, k 종의 변환기, 변환기 (u, v) 는 u 콘센트 가 필요 한 전 기 를 v 콘센트 에 연결 할 수 있 음 을 나타 낸다. 최소 몇 개의 장치 가 콘센트 가 없 는 지 물 어보 고 각 변환기 의 수량 은 제한 되 지 않 는 다.
#include
#include
#include
#include
#include
#include
#include
#define inf 1e9
using namespace std;
const int maxn = 1500;
const int maxm = 5500;
int n, m, k;
int num_nodes;
int a[30];
mapmp;

struct Edge  
{  
    int from, to, flow, cap;  
}edge[maxm*2];  
  
vectorG[maxn]; 
int edgenum;  
void add(int u, int v, int c) 
{  
    edge[edgenum].from = u;  
    edge[edgenum].to = v;  
    edge[edgenum].flow = 0;  
    edge[edgenum].cap = c;  
    edgenum++;  
      
    edge[edgenum].from = v;  
    edge[edgenum].to = u;  
    edge[edgenum].flow = 0;  
    edge[edgenum].cap = 0;  
    edgenum++;  
      
    G[u].push_back(edgenum-2);  
    G[v].push_back(edgenum-1);  
}  
  
int deep[maxn];  
bool vis[maxn];  
void BFS(int s, int t)  
{  
    queueQ;  
    memset(vis, false, sizeof vis);  
    Q.push(t);  
    vis[t] = true;  
    deep[t] = 0;  
    while(!Q.empty())  
    {  
        int now = Q.front();  
        Q.pop();  
        for(int i = 0;i e.flow && deep[begin] == deep[e.to] + 1) 
			{  
                front[e.to] = G[begin][i];  
                cur[begin] = i;  
                flag = true;  
                begin = e.to;  
                break;  
            }  
        }  
        if(!flag)  
        {  
            int k = num_nodes-1;  
            for(int i = 0;i e.flow)  
                    k = min(k, deep[e.to]);  
            }  
            if(--gap[deep[begin]] == 0) break; 
            gap[deep[begin] = k+1]++;  
            cur[begin] = 0;  
            if(begin != s)   
                begin = edge[front[begin]].from;   
        }  
    }  
    return flow;  
}  
  
void init() 
{  
    for(int i = 0;i

좋은 웹페이지 즐겨찾기