博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 1274 The Perfect Stall(二分图 && 匈牙利 && 最小点覆盖)
阅读量:5324 次
发布时间:2019-06-14

本文共 1276 字,大约阅读时间需要 4 分钟。

嗯...

 

题目链接:http://poj.org/problem?id=1274

 

一道很经典的匈牙利算法的题目:

将每只奶牛看成二分图中左边的点,将牛圈看成二分图中右边的点,如果奶牛看上某个牛圈,就将两点之间连边,然后跑一边匈牙利就行了...

 

AC代码:

1 #include
2 #include
3 #include
4 5 using namespace std; 6 7 int n, m, match[205], g[205][205], vis[205]; 8 9 inline int dfs(int u){10 for(int i = 1; i <= m; i++){11 if(g[u][i] && !vis[i]){12 vis[i] = 1;13 if(!match[i] || dfs(match[i])){14 match[i] = u;15 return 1;16 }17 }18 }19 return 0;20 }21 22 inline int hungary(){23 int ans = 0;24 for(int i = 1; i <= n; i++){25 memset(vis, 0, sizeof(vis));26 if(dfs(i)) ans++;27 }28 return ans;29 }30 31 int main(){32 while(~scanf("%d%d", &n, &m)){33 memset(g, 0, sizeof(g));34 memset(match, 0, sizeof(match));35 for(int i = 1; i <= n; i++){36 int s;37 scanf("%d", &s);38 for(int j = 1; j <= s; j++){39 int t;40 scanf("%d", &t);41 g[i][t] = 1;42 }43 }44 printf("%d\n", hungary());45 }46 return 0;47 }
AC代码

 

转载于:https://www.cnblogs.com/New-ljx/p/11420923.html

你可能感兴趣的文章
posix多线程有感--线程高级编程(线程属性函数总结)(代码)
查看>>
spring-使用MyEcilpse创建demo
查看>>
DCDC(4.5V to 23V -3.3V)
查看>>
kettle导数到user_用于left join_20160928
查看>>
activity 保存数据
查看>>
typescript深copy和浅copy
查看>>
linux下的静态库与动态库详解
查看>>
hbuilder调底层运用,多张图片上传
查看>>
深入理解基于selenium的二次开发
查看>>
较快的maven的settings.xml文件
查看>>
Git之初体验 持续更新
查看>>
Exception in thread "AWT-EventQueue-0" java.lang.IllegalThreadStateException
查看>>
随手练——HDU 5015 矩阵快速幂
查看>>
启动redis一闪就关
查看>>
Maven之setting.xml配置文件详解
查看>>
ASP.NET 4.5 Web Forms and Visual Studio vs2013年入门1
查看>>
SDK目录结构
查看>>
malloc() & free()
查看>>
HDU 2063 过山车
查看>>
高精度1--加法
查看>>