Chinaunix首页 | 论坛 | 博客
  • 博客访问: 38531
  • 博文数量: 64
  • 博客积分: 2640
  • 博客等级: 少校
  • 技术积分: 670
  • 用 户 组: 普通用户
  • 注册时间: 2010-01-26 13:15
文章分类
文章存档

2010年(64)

我的朋友
最近访客

分类: C/C++

2010-01-26 13:55:05

 2009-03-30 17:42

#include<iostream>
#include<fstream>
using namespace std;

const int MAX = 100;

struct{
      int n;
      int adjvex[MAX];
}Edge[MAX];

int xn,n;

bool vs[MAX];
int Match[MAX];

int Hungary();

int main(void){
    int e,a,b;
    int i,j;
    ifstream in("data.in");
    ofstream out("data.out");
   
    in>>xn>>n>>e;
    for(i=0;i<=n+1;i++)
        Edge[i].n = 0;
   
    for(i=0;i<e;i++){
        in>>a>>b;
        Edge[a].adjvex[ Edge[a].n++ ] = b;
    }
   
    out<<Hungary()<<endl;
    for(i=xn+1;i<=n;i++)
        out<<"Match["<<i<<"]="<<Match[i]<<endl;
   
    system("pause");
    return 0;
}

bool Add(int cur){
     int i,j,u,v;
    
     for(i=0;i<Edge[cur].n;i++){
         u = Edge[cur].adjvex[i];
         if(!vs[u]){
            vs[u] = true;
            if(Match[u]==0){
               Match[u] = cur;
               return true;
            }
            else if(Add(Match[u]) ){
                 Match[u] = cur;
                 return true;
            }
         }
     }
    
     return false;
}

int Hungary(){
    int i,r;
   
    memset(Match,0,sizeof(Match) );
    r = 0;
    for(i=1;i<=xn;i++){
        memset(vs,0,sizeof(vs) );
        if(Add(i) ) r++;
    }
   
    return r;
}


阅读(183) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~