poj Antenna Placement(二分图的匹配)

是最小路径覆盖问题:最小路径覆盖=最小路径覆盖=|G|-最大匹配数 
#include
<stdio.h> #include<string.h> const int maxn = 40*10+10; int maps[45][15],g[maxn][maxn],linker[maxn],vis[maxn],uN,vN; int dfs(int u) { for(int v = 1; v <= vN; v++) if(!vis[v] && g[u][v]) { vis[v] = 1; if(linker[v] == -1 || dfs(linker[v])) { linker[v] = u; return 1; } } return 0; } int hungary() { int sum = 0; memset(linker,-1,sizeof(linker)); for(int u = 1; u <= uN; u++) { memset(vis,0,sizeof(vis)); if(dfs(u)) sum++; } return sum; } int main() { int T,row,col; scanf("%d",&T); while(T--) { scanf("%d%d%*c", &row,&col); char c; int num = 0; memset(maps,0,sizeof(maps)); memset(g,0,sizeof(g)); for(int i = 1; i <= row; i++) { for(int j = 1; j <= col; j++) { scanf("%c", &c); if(c == '*') maps[i][j] = ++num; } getchar(); } uN = vN = num; for(int i = 1; i <= row; i++) { for(int j = 1; j <= col; j++) { if(maps[i][j]) { if(maps[i][j+1]) g[maps[i][j]][maps[i][j+1]] = 1; if(maps[i][j-1]) g[maps[i][j]][maps[i][j-1]] = 1; if(maps[i+1][j]) g[maps[i][j]][maps[i+1][j]] = 1; if(maps[i-1][j]) g[maps[i][j]][maps[i-1][j]] = 1; } } } printf("%d\n", num-hungary()/2); } return 0; }

转载于:https://www.cnblogs.com/You-Change/p/3530226.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值