poj3041-Asteroids , 二分图的最小顶点覆盖数 = 最大匹配数
2014-10-02 12:19
591 查看
点击打开链接
Konig定理:二分图的最小顶点覆盖数 = 二分图的最大匹配数
题意: 在N*N的网络中有K颗小行星。小行星i的位置是(Ri, Ci)。如今有一个强力的武器可以用一发光束将一整行或一整列的小行星消灭。想要利用这个武器消灭全部的小行星最少须要几发光束?
分析: 以小行星的左右坐标建立二分图,就能够看出是求二分图的最小顶点覆盖数。
Konig定理:二分图的最小顶点覆盖数 = 二分图的最大匹配数
题意: 在N*N的网络中有K颗小行星。小行星i的位置是(Ri, Ci)。如今有一个强力的武器可以用一发光束将一整行或一整列的小行星消灭。想要利用这个武器消灭全部的小行星最少须要几发光束?
分析: 以小行星的左右坐标建立二分图,就能够看出是求二分图的最小顶点覆盖数。
#include <cstdio> #include <cstring> #include <vector> #include <algorithm> using namespace std; const int maxn = 500 + 5; //单側顶点的最大数目 struct BPM{ int n, m; //左右顶点个数 vector<int> G[maxn]; //邻接表 int left[maxn];//left[i]为右边第i个点的匹配点编号,-1表示不存在 bool T[maxn];//T[i]为右边第i个点是否已标记 int right[maxn]; //求最小覆盖用 bool S[maxn]; //求最小覆盖用 void init(int n, int m){ this->n = n; this->m = m; for(int i=0; i<n; ++i) G[i].clear(); } void AddEdge(int u, int v){ G[u].push_back(v); } bool match(int u){ S[u] = true; for(int i=0; i<G[u].size(); ++i){ int v = G[u][i]; if(!T[v]){ T[v] = true; if(left[v]==-1 || match(left[v])){ left[v] = u; right[u] = v; return true; } } } return false; } //求最大匹配 int solve() { memset(left, -1, sizeof left ); memset(right, -1, sizeof right ); int ans = 0; for(int u=0; u<n; ++u){ //从左边结点u開始增广 memset(S, 0, sizeof S ); memset(T, 0, sizeof T ); if(match(u)) ans++; } return ans; } //求最小覆盖。 X 和 Y为最小覆盖中的点集 int mincover(vector<int>& X, vector<int>& Y){ int ans = solve(); memset(S, 0, sizeof S ); for(int u =0; u<n; ++u) if(right[u]==-1) match(u); //从全部X未盖点出发增广 for(int u=0; u<n; ++u) if(!S[u]) X.push_back(u); //X中的未标记点 for(int v=0; v<m; ++v) if(T[v]) Y.push_back(v); //Y中的已标记点 return ans; } }; BPM solver; int main() { int i, j, n, k; scanf("%d%d", &n, &k); solver.init(n, n); for(i=0; i<k; ++i) { int x, y; scanf("%d%d", &x, &y); x--; y--; solver.AddEdge(x, y); //有向图 } int ans = solver.solve(); printf("%d\n", ans); return 0; }
相关文章推荐
- poj3041-Asteroids , 二分图的最小顶点覆盖数 = 最大匹配数
- POJ3041 Asteroids 二分图最小顶点覆盖 Dinic求解最大流
- CUGB图论专场2:B - Asteroids 二分图:最小顶点覆盖=最大匹配数
- hdu 1054 Strategic Game 最小顶点覆盖(二分图最大匹配)
- poj3020_最小覆盖路径(顶点个数-二分图最大匹配数)
- poj 3041 Asteroids (二分图最大匹配 == 最小点覆盖数)
- HDOJ---1151 Air Raid[匈牙利算法:最小路径覆盖数=原图顶点数–二分图最大匹配数]
- poj3041 - Asteroids (二分图最小顶点覆盖)
- Machine Schedule HDoj (二分图最小顶点覆盖--最大匹配数)
- Asteroids(POJ--3041 【二分图的最小顶点集 = 二分图的最大匹配】
- poj 3041 Asteroids(二分图 *【矩阵实现】【最小点覆盖==最大匹配数】)
- [poj3041]Asteroids(二分图的最小顶点覆盖)
- poj3041-Asteroids(最小点覆盖,最大匹配)
- POJ3692——Kindergarten (二分图求最小顶点覆盖 (即最大匹配))
- poj 3041 Asteroids (最大匹配最小顶点覆盖——匈牙利模板题)
- 二分图最大匹配与最小顶点覆盖(教程系列)uva11419——我目前关于最大匹配最清晰的解释。
- POJ3041《Asteroids》方法:匈牙利算法(最小点覆盖数==最大二分匹配数)
- HDU 1150 Machine Schedule(匈牙利算法 二分图的最小顶点覆盖 二分图最大匹配)
- POJ 3041 Asteroids 最小点覆盖 == 二分图的最大匹配
- POJ 3401 Asteroids 二分图最大匹配 最小点覆盖