HDU 2819 隐式二分图匹配
http://acm.hdu.edu.cn/showproblem.php?pid=2819
这道题乍一看是矩阵变换题,估计用矩阵之类的也可以做
但是分析一下就可以知道
要凑成对角线都是1,题目允许行变换和列变换
然而观察可以得知如果可以完成只需要行变换或者列变换之一即可
donser[i][j]=1表示i,j位置有1,那么只需要变换j到i(即交换i,j行)
输出中间过程用queue
加上dfs遍历即可
#include<iostream>
#include<cstdio>
#include<queue>
#include<cstring>
using namespace std;
int donser[][];
bool used[];
int leave[],a[],b[];
int M,num,abc,j;
queue<int >que;
void swap(int i,int j)
{
int t=leave[i];leave[i]=leave[j];leave[j]=t;
}
int dfs(int x)
{
for(int i=;i<=M;i++)
{
if(donser[x][i]&&!used[i])
{
used[i]=true;
if(!leave[i]||dfs(leave[i]))
{
leave[i]=x;
return ;
} }
}
return ;
}
int main()
{
while(~scanf("%d",&M))
{
memset(donser,,sizeof(donser));
memset(leave,,sizeof(leave));
for(int i=;i<=M;i++)
{
for(j=;j<=M;j++)
{
scanf("%d",&num);
if(num) {donser[i][j]=;}
}
}
num=abc=;
for(int i=;i<=M;i++)
{
memset(used,,sizeof(used));
if(dfs(i)){abc++;}
}
if(abc!=M) {cout<<"-1"<<endl;continue;}
abc=,j=;
for(int i=;i<=M;i++)
{
for(j=;j<=M && leave[j]!=i ;j++);
if(i!=j)
{
abc++;
que.push(i);
que.push(j);
swap(i,j);
}
}
cout<<abc<<endl;
while(!que.empty())
{
cout<<"C "<<que.front();
que.pop();
cout<<" "<<que.front()<<endl;
que.pop();
}
abc=;
}
return ;
}
HDU 2819 隐式二分图匹配的更多相关文章
- HDU 2819 Swap(二分图匹配)
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=2819 [题目大意] 给出一个棋盘,由白格子和黑格子组成,可以交换棋盘的行列, 使得其主对角线为黑格 ...
- Android隐式启动匹配:action,category,data
简介 Android开发中,Activity,Service 和 BroadcastReceiver 启动有两种方式,显示启动和隐式启动. 为方便下面描述,我以Activity启动为例. 显示启动便是 ...
- HDU 1083 网络流之二分图匹配
http://acm.hdu.edu.cn/showproblem.php?pid=1083 二分图匹配用得很多 这道题只需要简化的二分匹配 #include<iostream> #inc ...
- hdu 5727 Necklace dfs+二分图匹配
Necklace/center> 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5727 Description SJX has 2*N mag ...
- HDU 5727 Necklace(二分图匹配)
[题目链接]http://acm.hdu.edu.cn/showproblem.php?pid=5727 [题目大意] 现在有n颗阴珠子和n颗阳珠子,将它们阴阳相间圆排列构成一个环,已知有些阴珠子和阳 ...
- Linux防火墙之iptables基本匹配条件和隐式扩展匹配条件
一.iptables的基本匹配条件 上一篇博文我们说到了iptables的基本工作原理.数据报文在内核的走向和管理链.管理规则.以及查看规则.导入和导出规则:回顾请参考https://www.cnbl ...
- hdu 5943(素数间隔+二分图匹配)
Kingdom of Obsession Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Oth ...
- HDU 5727 - Necklace - [全排列+二分图匹配][Hopcroft-Karp算法模板]
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=5727 Problem DescriptionSJX has 2*N magic gems. ...
- hdu - 1150 Machine Schedule (二分图匹配最小点覆盖)
http://acm.hdu.edu.cn/showproblem.php?pid=1150 有两种机器,A机器有n种模式,B机器有m种模式,现在有k个任务需要执行,没切换一个任务机器就需要重启一次, ...
随机推荐
- 基于Python实现对PDF文件的OCR识别
http://www.jb51.net/article/89955.htm https://pythontips.com/2016/02/25/ocr-on-pdf-files-using-pytho ...
- System类
System类是一些与系统相关属性和方法的集合,而且System类中所有的属性都是静态的,要想引用这些属性和方法,直接使用System类调用即可. //======================== ...
- notification的使用
示例: NotificationManager nm = (NotificationManager)getSystemService(Context.NOTIFICATION_SERVICE); No ...
- FreeImage使用
http://blog.csdn.net/byxdaz/article/details/6056509 http://blog.chinaunix.net/uid-20660110-id-65639. ...
- asp.net常用函数表
文章转载于[IT花园]:http://www.itgarden.com.cn/showtopic-29.aspx Abs(number) 取得数值的绝对值. Asc(String) 取得字符串表达式的 ...
- Docker Compose to CoreOS
taken from https://docs.docker.com/compose/install/ the only thing is that /usr is read only, but /o ...
- C#如何把List of Object转换成List of T具体类型
上周码程序的时候碰到个问题,因为设计上的约束,一个方法接受的参数只能为List<object>类型,然而该方法需要处理的真实数据则是确定的List<Currency>.然而C# ...
- Python之with语句
Python之with语句 在Python中,我们在打开文件的时候,为了代码的健壮性,通常要考虑一些异常情况,比如: try: ccfile = open('/path/data') content ...
- java语言一维数组,对象数组
/** * 对象数组的使用 */package com.test5; import java.io.BufferedReader;import java.io.InputStream;import j ...
- Orchard源码分析(4.4):Orchard.Caching.CacheModule类
概述 CacheModule也是一个Autofac模块. 一.CacheModule类 CacheModule将DefaultCacheManager注册为ICacheManager: ...