poj1325机器工作——二分图最小点覆盖
题目:http://poj.org/problem?id=1325
二分图求最大匹配,即为最小点覆盖;
一开始我写得较麻烦,求出最大匹配又去搜增广路,打标记求最小点覆盖;
然而两种方法都没写“ans=0”,WA了好几次,心力交瘁时才发现,改后即A,心力交瘁。
代码1如下:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,m,k,pre1[305],pre2[305],head[305],ct,ans;
bool vis[305];
struct N{
int to,next;
}edge[3005];
void add(int x,int y)
{
ct++;
edge[ct].to=y;
edge[ct].next=head[x];
head[x]=ct;
}
bool dfs(int b)
{
for(int i=head[b];i;i=edge[i].next)
{
int a=edge[i].to;
if(vis[a])continue;
vis[a]=1;
if(!pre1[a]||dfs(pre1[a]))
{
pre1[a]=b;
pre2[b]=a;
return 1;
}
}
return 0;
}
bool dfs2(int b)
{
vis[b]=1;
for(int i=head[b];i;i=edge[i].next)
{
int a=edge[i].to;
if(vis[a])continue;
vis[a]=1;
if(!pre1[a]||dfs2(pre1[a]))
{
pre1[a]=b;
pre2[b]=a;
return 1;
}
}
return 0;
}
int main()
{
while(1)
{
ct=0;ans=0;//!
memset(pre1,0,sizeof pre1);
memset(pre2,0,sizeof pre2);
memset(head,0,sizeof head);
scanf("%d",&n);
if(!n)return 0;
scanf("%d%d",&m,&k);
int d,a,b;
for(int i=1;i<=k;i++)
{
scanf("%d%d%d",&d,&a,&b);
if(a*b==0)continue;
add(a+100,b);
add(b,a+100);
}
for(int i=1;i<m;i++)//最大匹配
if(!pre2[i])
{
memset(vis,0,sizeof vis);
vis[i]=1;//
dfs(i);
}
memset(vis,0,sizeof vis);
for(int i=1;i<m;i++)
if(!pre2[i])
dfs2(i);
for(int i=1;i<m;i++)
if(!vis[i])ans++;
for(int i=101;i<n+100;i++)
if(vis[i])ans++;
printf("%d\n",ans);
}
}
代码2如下:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,m,k,pre[305],head[305],ct,ans;
bool vis[305];
struct N{
int to,next;
}edge[3005];
void add(int x,int y)
{
ct++;
edge[ct].to=y;
edge[ct].next=head[x];
head[x]=ct;
}
bool dfs(int b)
{
vis[b]=1;
for(int i=head[b];i;i=edge[i].next)
{
int a=edge[i].to;
if(vis[a])continue;
vis[a]=1;
if(!pre[a]||dfs(pre[a]))
{
pre[a]=b;
pre[b]=a;
return 1;
}
}
return 0;
} int main()
{
while(1)
{
ct=0;ans=0;//
memset(pre,0,sizeof pre);
memset(head,0,sizeof head);
scanf("%d",&n);
if(!n)return 0;
scanf("%d%d",&m,&k);
int d,a,b;
for(int i=1;i<=k;i++)
{
scanf("%d%d%d",&d,&a,&b);
if(a*b==0)continue;
add(a+100,b);
add(b,a+100);
}
for(int i=1;i<m;i++)//最大匹配
if(!pre[i])
{
memset(vis,0,sizeof vis);
if(dfs(i))ans++;
}
printf("%d\n",ans);
}
}
poj1325机器工作——二分图最小点覆盖的更多相关文章
- [poj1325] Machine Schedule (二分图最小点覆盖)
传送门 Description As we all know, machine scheduling is a very classical problem in computer science a ...
- POJ1325 Machine Schedule(二分图最小点覆盖集)
最小点覆盖集就是在一个有向图中选出最少的点集,使其覆盖所有的边. 二分图最小点覆盖集=二分图最大匹配(二分图最大边独立集) 这题A机器的n种模式作为X部的点,B机器的m种模式作为Y部的点: 每个任务就 ...
- UVA1194 Machine Schedule[二分图最小点覆盖]
题意翻译 有两台机器 A,B 分别有 n,m 种模式. 现在有 k 个任务.对于每个任务 i ,给定两个整数$ a_i\(和\) b_i$,表示如果该任务在 A上执行,需要设置模式为 \(a_i\): ...
- POJ2226 Muddy Fields(二分图最小点覆盖集)
题目给张R×C的地图,地图上*表示泥地..表示草地,问最少要几块宽1长任意木板才能盖住所有泥地,木板可以重合但不能盖住草地. 把所有行和列连续的泥地(可以放一块木板铺满的)看作点且行和列连续泥地分别作 ...
- hihoCoder #1127:二分图最小点覆盖和最大独立集
题目大意:求二分图最小点覆盖和最大独立集. 题目分析:如果选中一个点,那么与这个点相连的所有边都被覆盖,使所有边都被覆盖的最小点集称为最小点覆盖,它等于最大匹配:任意两个点之间都没有边相连的最大点集称 ...
- [POJ] 2226 Muddy Fields(二分图最小点覆盖)
题目地址:http://poj.org/problem?id=2226 二分图的题目关键在于建图.因为“*”的地方只有两种木板覆盖方式:水平或竖直,所以运用这种方式进行二分.首先按行排列,算出每个&q ...
- 二分图 最小点覆盖 poj 3041
题目链接:Asteroids - POJ 3041 - Virtual Judge https://vjudge.net/problem/POJ-3041 第一行输入一个n和一个m表示在n*n的网格 ...
- HihoCoder1127 二分图三·二分图最小点覆盖和最大独立集
二分图三·二分图最小点覆盖和最大独立集 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 在上次安排完相亲之后又过了挺长时间,大家好像都差不多见过面了.不过相亲这个事不是说 ...
- 四川第七届 D Vertex Cover(二分图最小点覆盖,二分匹配模板)
Vertex Cover frog has a graph with nn vertices v(1),v(2),…,v(n)v(1),v(2),…,v(n) and mm edges (v(a1), ...
随机推荐
- ubuntu boost.python
安装boost(未尝试只安装 libboost-python-dev) sudo apt-get install libboost-all-dev 新建hello_ext.cpp,输入以下代码 1 c ...
- jdbcTemplaate queryForObject的两个易混淆的方法
JdbcTemplate中有两个可能会混淆的queryForObject方法: 1. Object queryForObject(String sql, Object[] args, Class ...
- linux下复制文件夹命令
在源文件的目录下,对其进行cp操作,到后面的目标路径,对其进行文件夹复制 cp -rf /home/wangshiming/Downloads/* /home/wangshiming/tools
- PowerBuilder -- 结构类型(structure)
http://bbs.csdn.net/topics/3501120743楼答复 PB的structure分两种,全局的和局部的,两者只有作用域不同. 全局的在file/new/pb object/s ...
- 百思不得姐之"我的"模块功能(六)
一 功能图和知识点 1 功能图部分:(因为网速的原因,网页部分没有载入出来,可是功能完善) 2 该部分能学到的知识点概括: >1 UITableView的使用(简单) >2 UIColle ...
- c 字符串 函数
c编辑 strcpy 原型:extern char *strcpy(char *dest,char *src); 用法:#include <string.h> 功能:把src所指由NUL结 ...
- ASP.NET动态网站制作(10)-- JQ(2)
前言:jq的第二节课. 内容: 1.管理选择结果: (1)获取元素个数:$("img").size():获取页面中所有“img”个数: (2)提取元素:$("img[ ...
- ios 添加全屏返回手势
1 建立导航控制器 2.导航控制器添加如下代码 - (void)viewDidLoad { [super viewDidLoad]; id target = self.interactivePopGe ...
- doT.js具体使用介绍
官网: http://olado.github.iodoT.js具体使用介绍 用法: {{= }} for interpolation {{ }} for evaluation {{~ }} for ...
- System.TypeLoadException: Could not load type 'System.IO.Compression.CompressionLevel' from assembly 'System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089'.
1.提示错误信息: zipSystem.TypeLoadException: Could not load type 'System.IO.Compression.CompressionLevel' ...