二分图匹配(KM算法)n^3 分类: ACM TYPE 2014-10-01 21:46 98人阅读 评论(0) 收藏
2014-10-01 21:46
453 查看
#include <iostream> #include<cstring> #include<cstdio> #include<cmath> const int maxn = 301; const int INF = (1<<31)-1; int w[maxn][maxn]; int lx[maxn],ly[maxn]; //顶标 int linky[maxn]; int visx[maxn],visy[maxn]; int slack[maxn]; int n; bool find(int x) { visx[x] = true; for(int y = 1; y <=n; y++) { if(visy[y]) continue; int t = lx[x] + ly[y] - w[x][y]; if(t==0) { visy[y] = true; if(linky[y] == -1 || find(linky[y])) { linky[y] = x; return true; } } else if(slack[y] > t) slack[y] = t; } return false; } int KM() { int i,j; memset(linky,-1,sizeof(linky)); memset(ly,0,sizeof(ly)); for(i = 1; i <=n; i++) //初始化顶标 { lx[i] = -INF; for(j = 1; j <=n; j++) { if(w[i][j] > lx[i]) lx[i] = w[i][j]; } } for(int x = 1; x <=n; x++) { for(i = 1; i <=n; i++) slack[i] = INF; while(true) { memset(visx,0,sizeof(visx)); memset(visy,0,sizeof(visy)); if(find(x)) break; int d = INF; for(i = 1; i <=n; i++) { if(!visy[i] && d > slack[i]) d = slack[i]; } for(i = 1; i <=n; i++) { if(visx[i]) lx[i] -= d; } for(i = 1; i <=n; i++) { if(visy[i]) ly[i] += d; else slack[i] -= d; } } } int result = 0; for(i = 1; i <=n; i++) { if(linky[i]>-1) { result += w[linky[i]][i]; } } return result; } int main() { while(scanf("%d",&n)==1) { int cost; for(int i=1;i<=n;i++) { for(int j=1;j<=n;j++) { scanf("%d",&cost); w[i][j] = cost; } } printf("%d\n",KM()); } return 0; }更新顶标的问题的了
相关文章推荐
- 二分图匹配(KM算法)n^4 分类: ACM TYPE 2014-10-04 11:36 88人阅读 评论(0) 收藏
- 二分图匹配 分类: ACM TYPE 2014-10-01 19:57 94人阅读 评论(0) 收藏
- 【Nutch2.2.1基础教程之1】nutch相关异常 分类: H3_NUTCH 2014-08-08 21:46 1549人阅读 评论(2) 收藏
- 博弈论入门小结 分类: ACM TYPE 2014-08-31 10:15 73人阅读 评论(0) 收藏
- android异步任务详解 AsynTask 分类: Android Activity 2014-07-03 07:20 98人阅读 评论(0) 收藏
- max_flow(Dinic) 分类: ACM TYPE 2014-09-02 15:42 94人阅读 评论(0) 收藏
- Xcode和mac快捷键 分类: ios开发 mac电脑操作 2014-12-27 21:46 167人阅读 评论(0) 收藏
- Codeforces 343D Water Tree 分类: Brush Mode 2014-10-05 14:38 98人阅读 评论(0) 收藏
- 【转载】fscanf和fprintf函数从文件中格式化读取double型数据 分类: Linux --- C 2014-11-11 18:45 98人阅读 评论(0) 收藏
- hash值的计算与转换 分类: ACM TYPE 2015-05-07 17:49 36人阅读 评论(0) 收藏
- 怎么在window的dos下安装apk到指定… 分类: Android安装及配置 2014-05-30 10:59 98人阅读 评论(0) 收藏
- short-path problem (Dijkstra) 分类: ACM TYPE 2014-09-01 23:51 111人阅读 评论(0) 收藏
- short-path problem (Floyd) 分类: ACM TYPE 2014-09-01 23:58 100人阅读 评论(0) 收藏
- CursorAdapter类的使用 分类: Android界面和组件 2014-06-12 14:34 98人阅读 评论(0) 收藏
- Overview 分类: Cocos2d-x 2015-02-09 18:16 98人阅读 评论(0) 收藏
- short-path problem (Spfa) 分类: ACM TYPE 2014-09-02 00:30 103人阅读 评论(0) 收藏
- Least Common Ancestors 分类: ACM TYPE 2014-10-19 11:24 84人阅读 评论(0) 收藏
- Keil C51 的printf 分类: 嵌入式开发学习 2015-03-31 14:15 98人阅读 评论(0) 收藏
- Segment Tree with Lazy 分类: ACM TYPE 2014-08-29 11:28 134人阅读 评论(0) 收藏
- Segment Tree 分类: ACM TYPE 2014-08-29 13:04 97人阅读 评论(0) 收藏