zoukankan      html  css  js  c++  java
  • [HDU] 2063 过山车(二分图最大匹配)

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=2063

    女生为X集合,男生为Y集合,求二分图最大匹配数即可。

     1 #include<cstdio>
     2 #include<iostream>
     3 #include<string.h>
     4 #include<algorithm>
     5 #include<math.h>
     6 #include<stdbool.h>
     7 #include<time.h>
     8 #include<stdlib.h>
     9 #include<set>
    10 #include<map>
    11 #include<stack>
    12 #include<queue>
    13 #include<vector>
    14 using namespace std;
    15 #define clr(x,y)    memset(x,y,sizeof(x))
    16 #define sqr(x)      ((x)*(x))
    17 #define rep(i,a,b)  for(int i=(a);i<=(b);i++)
    18 #define LL          long long
    19 #define INF         0x3f3f3f3f
    20 #define A           first
    21 #define B           second
    22 #define PI          acos(-1.0)
    23 const int N=500+131;
    24 int n,m,k,f[N],g[N][N],link[N];
    25 
    26 void init()
    27 {
    28     clr(f,0);
    29     clr(g,0);
    30     clr(link,-1);
    31 }
    32 
    33 bool find(int x)
    34 {
    35     for(int i=1;i<=n;i++) {
    36         if(!f[i] && g[x][i]) {
    37             f[i]=1;
    38             if(link[i]==-1 || find(link[i])) {
    39                 link[i]=x;
    40                 return true;
    41             }
    42         }
    43     }
    44     
    45     return false;
    46 }
    47 
    48 int hungary()
    49 {
    50     int ans=0;
    51     for(int i=1;i<=m;i++) {
    52         clr(f,0);
    53         if(find(i)) ans++;
    54     }
    55     return ans;
    56 }
    57 
    58 int main()
    59 {
    60     int u,v,k;
    61     
    62     while(~scanf("%d",&k)) {
    63         if(!k) break;
    64         init();
    65         scanf("%d%d",&m,&n);
    66         while(k--) {
    67             scanf("%d%d",&u,&v);
    68             g[u][v]=1;
    69         }
    70         printf("%d
    ",hungary());
    71     }
    72    
    73     
    74     
    75     return 0;
    76 }
  • 相关阅读:
    C++之容器
    C++之复制控制
    TCP的3次握手/4次握手
    linux编程之多线程编程
    linux编程之信号
    linux编程之共享内存
    MySQL数据库优化
    MySQL存储引擎InnoDB与Myisam
    Redis--持久化
    Redis 请求应答模式和往返延时 Pipelining
  • 原文地址:https://www.cnblogs.com/sxiszero/p/4379358.html
Copyright © 2011-2022 走看看