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), ...
随机推荐
- js的常用小技巧
//类对象转成数组 var domNodes = Array.prototype.slice.call(document.getElementsByTagName("*")); ...
- SQL Server外连接、内连接、交叉连接
小编在做组织部维护最后收尾工作的时候,遇到了这样一个问题,须要将定性考核得分查出来.定量考核相应的数据查出来并进行得分计算.附加分查出来,最后将这三部分信息汇总之后得到总成绩,假设当中一项成绩没有进行 ...
- PHP中__get()和__set()的用法实例详解
php面向对象_get(),_set()的用法 一般来说,总是把类的属性定义为private,这更符合现实的逻辑.但是,对属性的读取和赋值操作是非常频繁的,因此在PHP5中,预定义了两个函数“__ge ...
- js new一个函数和直接调用函数的差别
用new和调用一个函数的差别:假设函数返回值是一个值类型(Number.String.Boolen)时,new函数将会返回这个函数的实例对象.而假设这个函数的返回值是一个引用类型(Object.Arr ...
- php生成唯一的串
1.方法一: <?php md5(uniqid('aa',true)); ?> 2.方法2: //生成16位的串$randLength=6; $chars='abcdefghijklmno ...
- Touch ID和Passcode框架,Apple Watch风格的应用布局
本文转载至 http://www.cocoachina.com/ios/20141031/10110.html 水平滚动条(artwalk) 测试环境:Xcode 6.0,iOS 8.0 VE ...
- mongodb.py
from chatterbot.storage import StorageAdapter class Query(object): def __init__(self, query={}): sel ...
- 1355: [Baltic2009]Radio Transmission[循环节]
1355: [Baltic2009]Radio Transmission Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 796 Solved: 538 ...
- EasyNVR流媒体服务器接入EasyDSS云视频平台快照上传实现
EasyNVR拥有接入EasyDSS云平台的功能 接入EasyDSS云平台会定时向云平台上传快照数据,这个快照数据用于云平台向客户端提供快照展示 遇到的问题 由于快照上传的间隔提供认为修改的功能,则我 ...
- mysqldump的--master-data参数
mysqldump导出数据时,当这个参数的值为1的时候,mysqldump出来的文件就会包括CHANGE MASTER TO这个语句,CHANGE MASTER TO后面紧接着就是file和posit ...