题目: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机器工作——二分图最小点覆盖的更多相关文章

  1. [poj1325] Machine Schedule (二分图最小点覆盖)

    传送门 Description As we all know, machine scheduling is a very classical problem in computer science a ...

  2. POJ1325 Machine Schedule(二分图最小点覆盖集)

    最小点覆盖集就是在一个有向图中选出最少的点集,使其覆盖所有的边. 二分图最小点覆盖集=二分图最大匹配(二分图最大边独立集) 这题A机器的n种模式作为X部的点,B机器的m种模式作为Y部的点: 每个任务就 ...

  3. UVA1194 Machine Schedule[二分图最小点覆盖]

    题意翻译 有两台机器 A,B 分别有 n,m 种模式. 现在有 k 个任务.对于每个任务 i ,给定两个整数$ a_i\(和\) b_i$,表示如果该任务在 A上执行,需要设置模式为 \(a_i\): ...

  4. POJ2226 Muddy Fields(二分图最小点覆盖集)

    题目给张R×C的地图,地图上*表示泥地..表示草地,问最少要几块宽1长任意木板才能盖住所有泥地,木板可以重合但不能盖住草地. 把所有行和列连续的泥地(可以放一块木板铺满的)看作点且行和列连续泥地分别作 ...

  5. hihoCoder #1127:二分图最小点覆盖和最大独立集

    题目大意:求二分图最小点覆盖和最大独立集. 题目分析:如果选中一个点,那么与这个点相连的所有边都被覆盖,使所有边都被覆盖的最小点集称为最小点覆盖,它等于最大匹配:任意两个点之间都没有边相连的最大点集称 ...

  6. [POJ] 2226 Muddy Fields(二分图最小点覆盖)

    题目地址:http://poj.org/problem?id=2226 二分图的题目关键在于建图.因为“*”的地方只有两种木板覆盖方式:水平或竖直,所以运用这种方式进行二分.首先按行排列,算出每个&q ...

  7. 二分图 最小点覆盖 poj 3041

    题目链接:Asteroids - POJ 3041 - Virtual Judge  https://vjudge.net/problem/POJ-3041 第一行输入一个n和一个m表示在n*n的网格 ...

  8. HihoCoder1127 二分图三·二分图最小点覆盖和最大独立集

    二分图三·二分图最小点覆盖和最大独立集 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 在上次安排完相亲之后又过了挺长时间,大家好像都差不多见过面了.不过相亲这个事不是说 ...

  9. 四川第七届 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), ...

随机推荐

  1. js 显示当前系统时间

    <div id="test"></div>                <script >                    setInt ...

  2. Spark源码分析之八:Task运行(二)

    在<Spark源码分析之七:Task运行(一)>一文中,我们详细叙述了Task运行的整体流程,最终Task被传输到Executor上,启动一个对应的TaskRunner线程,并且在线程池中 ...

  3. easyUI中 datagrid 一列字比较多时,出现省略符号

    当数据比较多为,出现省略符号 <style type="text/css">            .datagrid-cell, .datagrid-cell-gro ...

  4. maven nexus 搭建

    http://www.cnblogs.com/adolfmc/archive/2012/08/21/2648415.html http://www.cnblogs.com/dingyingsi/p/3 ...

  5. 在命令行上启用 64 位 Visual C++ 工具集

    Visual C++ 包含可用于创建 apps 在 32 位上运行,64 位,或基于 ARM 的 windows 操作系统的编译器. 下面的列表描述了 cl.exe(Visual C++ 编译器)的各 ...

  6. jQuery中slideToggle()的详细使用方法和解释

    $(selector).slideToggle(speed,callback) 参数       speed和callback Speed  可选.规定元素从隐藏到显示的速度,默认‘normal’可能 ...

  7. python 基础 1.5 python 数据类型(一)--整型 浮点型 布尔型及字符串和常用方法

    一.python 数据类型:数值,字符串,列表,元组,字典.以下操作是在linux 下 ipython中进行 1.数值 1>123  与  “123”的区别 答:123为数值,“123”在pyt ...

  8. asp.net mvc 中"未找到路径“/favicon.ico”的控制器或该控制器未实现 IController。"

    FavIcon.ico是一个特殊的文件,它是浏览器请求一个网站时出现的.某些浏览器在书签和收藏夹中使用这个图标.在与这些图标相关的网站被打开时,某些浏览器也在标题栏或浏览器标签中中显示这个图标. 当一 ...

  9. zendstudio 13.0

    官网原版下载 http://downloads.zend.com/studio-eclipse/13.0.0/ZendStudio-13.0.0-win32.win32.x86.exe 破解补丁: 链 ...

  10. 编写你的第一个web应用程序1

    在shell中运行以下命令来检查django是否已安装及其版本 python -m django --version 如果django已经安装,你应该看到安装的版本号,如果还没有安装,你会看到一个‘n ...