POJ 2594 最大二分匹配 最小路径覆盖
来源:互联网 发布:java 去除html标签 编辑:程序博客网 时间:2024/06/05 00:35
题目在: http://poj.org/problem?id=2594
因为是按照分类做题目,所以在明知这个题目是 最小路径覆盖的时候,就匆忙写好代码,提交,结果WA。
检查半天,结果发现题目中的提示:You should notice that the roads of two different robots may contain some same point.
而传统的最小路径覆盖的结果中,不同路径是不能出现重复点的。
所以这个题目中的 两个点之间是否可达就要重新定义了。
因为可以过相同的点,所以可以认为两个点,只要在按照图遍历的方法遍历的时候能遍历的到,就应该是联通的。
按照这个思路可以先用算法将 连接关系扩展,然后用扩展后的连接关系来 求最小路径覆盖:
#include <stdio.h>#include <memory.h>#define MAX_NUM 505int vvAdj[MAX_NUM][MAX_NUM];bool visit[MAX_NUM];int matched[MAX_NUM];int nPoints;bool dfs(int f){for(int i = 1; i <= nPoints; i++){if(!visit[i] && vvAdj[f][i]){visit[i] = true;if(matched[i] == -1 || dfs(matched[i])){matched[i] = f;return true;}}}return false;}void GetVVAdjacency(){int i,j,k;for( k = 1; k <= nPoints; k++){for( i = 1; i <= nPoints; i++){for( j = 1; j <= nPoints; j++){if( i != j){if(vvAdj[i][k] && vvAdj[k][j] ){vvAdj[i][j] = 1;}}}}}}int main(){int nRoad;while(scanf("%d%d",&nPoints, &nRoad) ){if(nPoints == 0 && nRoad == 0){break;}memset(matched, -1, sizeof(matched));memset(vvAdj, 0, sizeof(vvAdj));int i;int f,t;for( i = 0; i < nRoad; i++){scanf("%d%d", &f, &t);vvAdj[f][t] = 1;}GetVVAdjacency();int count = 0;for( i = 1; i <= nPoints; i++){memset(visit, 0, sizeof(visit));if(dfs(i)){count++;}}printf("%d\n", nPoints - count);}return 0;}
- POJ 2594 最大二分匹配 最小路径覆盖
- poj 2594 二分图最大匹配最小路径覆盖
- POJ 2594 最小路径覆盖 二分匹配
- 最小路径覆盖-二分图最大匹配 poj 1422
- poj 2594 Treasure Exploration(最小路径覆盖/二分最大匹配)
- 二分图-最大匹配,最小路径覆盖,最小点覆盖
- poj 2594 Treasure Exploration 最小路径覆盖/最大匹配
- poj 2594 Treasure Exploration(最小路径覆盖->最大匹配)
- POJ 3020 最小路径覆盖 = 顶点数-最大匹配数 二分匹配
- poj 1422 Air Raid(最小路径覆盖 + 二分图最大匹配)
- POJ 1422Air Raid(二分图最大匹配之最小路径覆盖)
- 二分图最大匹配,最小点覆盖,最小路径覆盖,二分图最大独立集
- [最小路径覆盖、二分图最大匹配]Pku3020--Antenna Placement
- 最小路径覆盖(二分图最大匹配):Air Raid
- hdu1151 poj1422 最小路径覆盖.最大二分匹配
- DAG最小路径覆盖与二分图最大匹配
- 网络流 最小路径覆盖 二分图最大匹配
- POJ 3041 匈牙利算法 最小覆盖 最大二分匹配
- hdu1266 Reverse Number (模拟)
- DOS实用命令
- UVa 10827 - Maximum sum on a torus
- hdu 1720 A+B Coming (进制转换)
- SVN提示文件被锁住以及Unlocker软件的使用
- POJ 2594 最大二分匹配 最小路径覆盖
- linux隐式密码输入(二)
- Eclipse CDT + QEMU 调试linux内核
- hdu 1708 Fibonacci String (递推)
- activemq的网络层介绍(一)
- UVa 108 - Maximum Sum
- linux隐式密码输入(一)
- activemq的网络层介绍(二)
- hdu 2103 Family planning (水)