HDU 4685
题意略。
思路:
本题和POJ1904颇为相似,只是那个最大匹配没有现成的,要我们自己求出来。并且要给每一个单身的王子/公主现找一个虚拟的对象。
这也是合乎情理的,王子每一次换一个公主时,可能会导致某一个王子失去他的原配,然而同样也会有另一个单身王子找到公主。
这里注意,每一个虚拟王子要喜欢所有公主,每一个虚拟公主要被所有王子喜欢。
详见代码:
#include<bits/stdc++.h>
using namespace std;
const int maxn = ; int linked[maxn],component[maxn],V,uN,n,m;
bool used[maxn],visit[maxn];
vector<int> store[maxn];
vector<int> G[maxn];
vector<int> rG[maxn];
vector<int> graph[maxn];
vector<int> vs; void add_edge(int from,int to){
G[from].push_back(to);
rG[to].push_back(from);
}
void dfs(int v){
used[v] = true;
for(int i = ;i < G[v].size();++i){
int to = G[v][i];
if(!used[to]) dfs(to);
}
vs.push_back(v);
}
void rdfs(int v,int k){
used[v] = true;
component[v] = k;
for(int i = ;i < rG[v].size();++i){
int to = rG[v][i];
if(!used[to]) rdfs(to,k);
}
}
int scc(){
memset(used,false,sizeof(used));
vs.clear();
for(int v = ;v <= V;++v){
if(!used[v]) dfs(v);
}
memset(used,false,sizeof(used));
int k = ;
for(int i = vs.size() - ;i >= ;--i){
if(!used[vs[i]]) rdfs(vs[i],k++);
}
return k;
}
bool dfs1(int u){
for(int i = ;i < graph[u].size();++i){
int v = graph[u][i];
if(used[v]) continue;
used[v] = true;
if(linked[v] == - || dfs1(linked[v])){
linked[v] = u;
return true;
}
}
return false;
}
int hungary(){
int ret = ;
memset(linked,-,sizeof(linked));
for(int u = ;u <= uN;++u){
memset(used,false,sizeof(used));
if(dfs1(u)) ++ret;
}
return ret;
}
void init(){
memset(component,,sizeof(component));
memset(visit,false,sizeof(visit));
for(int i = ;i < maxn;++i){
G[i].clear();
rG[i].clear();
store[i].clear();
graph[i].clear();
}
uN = n;
} int main(){
int T,cas = ;
scanf("%d",&T);
while(T--){
scanf("%d%d",&n,&m);
init();
for(int i = ;i <= n;++i){
int ki;
scanf("%d",&ki);
int t;
for(int j = ;j < ki;++j){
scanf("%d",&t);
graph[i].push_back(t);
add_edge(i,t + n);
}
}
int temp = hungary();
int tn = n - temp,tm = m - temp;
for(int i = ;i <= m;++i){
int from = i + n,to = linked[i];
if(to == -) continue;
add_edge(from,to);
visit[to] = true;
}
for(int i = n + m + ;i <= n + m + tm;++i){
bool signal = true;
for(int j = n + ;j <= n + m;++j){
add_edge(i,j);
if(signal && linked[j - n] == -){
signal = false;
add_edge(j,i);
linked[j - n] = i;
}
}
}
for(int i = n + m + tm + ;i <= n + m + tm + tn;++i){
bool signal = true;
for(int j = ;j <= n;++j){
add_edge(j,i);
if(visit[j] == false && signal){
signal = false;
visit[j] = true;
add_edge(i,j);
}
}
}
V = n + m + tm + tn;
int numb = scc();
for(int i = ;i <= n;++i){
for(int j = ;j < graph[i].size();++j){
int to = graph[i][j] + n;
if(to > n + m) continue;
int belong1 = component[i],
belong2 = component[to];
if(belong1 == belong2){
store[i].push_back(to - n);
}
}
sort(store[i].begin(),store[i].end());
}
printf("Case #%d:\n",cas++);
for(int i = ;i <= n;++i){
printf("%d",store[i].size());
for(int j = ;j < store[i].size();++j){
printf(" %d",store[i][j]);
}
printf("\n");
}
}
return ;
}
HDU 4685的更多相关文章
- POJ 1904 HDU 4685
这两道题差不多,POJ这道我很久以前就做过,但是比赛的时候居然没想起来.. POJ 这道题的题意是,N个王子每个人都有喜欢的公主,当他们选定一个公主结婚时,必须是的剩下的人也能找到他喜欢的公主结婚. ...
- hdu 4685 二分匹配+强连通分量
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4685 题解: 这一题是poj 1904的加强版,poj 1904王子和公主的人数是一样多的,并且给出 ...
- HDU 4685 Prince and Princess(二分图+强连通分量)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4685 题意:给出n个王子和m个公主.每个王子有一些自己喜欢的公主可以匹配.设最大匹配为M.那么对于每个 ...
- hdu 4685(强连通分量+二分图)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4685 题意:n个王子和m个公主,王子只能和他喜欢的公主结婚,公主可以和所有的王子结婚,输出所有王子可能 ...
- HDU 4685 Prince and Princess 二分图匹配+tarjan
Prince and Princess 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=4685 Description There are n pri ...
- hdu 4685(匹配+强连通分量)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4685 思路:想了好久,终于想明白了,懒得写了,直接copy大牛的思路了,写的非常好! 做法是先求一次最 ...
- hdu 4685(强连通分量+二分图的完美匹配)
传送门:Problem 4685 https://www.cnblogs.com/violet-acmer/p/9739990.html 参考资料: [1]:二分图的最大匹配.完美匹配和匈牙利算法 [ ...
- hdu 4685 简单匹配+Tarjan算法
思路:首先看到这题以为能用poj1904的模版直接A掉,WA了几次,然后又TLE了几次.还是想到了正解. 一开始我想的大致方向已经是对的了.先是由王子向每个喜欢的公主建边,再求一次最大匹配,找出匹配后 ...
- H - Prince and Princess - HDU 4685(二分匹配+强连通分量)
题意:有N个王子M个公主,王子喜欢一些公主,而且只能是王子喜欢的人,他们才可以结婚,现在让他们尽可能多的结婚的前提下找出来每个王子都可以和谁结婚. 分析:先求出来他们的最大匹配,因为给的数据未必是完备 ...
- hdu 4685 Prince and Princess(匈牙利算法 连通分量)
看了别人的题解.须要用到匈牙利算法的强连通算法 #include<cstdio> #include<algorithm> #include<vector> #pra ...
随机推荐
- Unity3D热更新之LuaFramework篇[07]--怎么让unity对象绑定Lua脚本
前言 在上一篇文章 Unity3D热更新之LuaFramework篇[06]--Lua中是怎么实现脚本生命周期的 中,我分析了由LuaBehaviour来实现lua脚本生命周期的方法. 但在实际使用中 ...
- 牛客第三场 J LRU management
起初看到这道题的时候,草草就放过去了,开了另一道题,结果开题不顺利,总是感觉差一点就可以做出来,以至于一直到最后都没能看这道题qaq 题意:类似于操作系统上讲的LRU算法,有两个操作,0操作代表访问其 ...
- Servlet高级应用
会话只是指一段指定的时间间隔. 会话跟踪是维护用户状态(数据)的一种方式.它也被称为servlet中的会话管理. Http协议是一个无状态的,所以我们需要使用会话跟踪技术来维护用户状态. 每次用户请求 ...
- thymeleaf常用属性
转 作者:ITPSC 出处:http://www.cnblogs.com/hjwublog/ th:action 定义后台控制器路径,类似<form>标签的action属性. 例如: ...
- 脱壳系列_2_IAT加密壳_详细版_解法1_包含脚本
1 查看壳程序信息 使用ExeInfoPe 分析: 发现这个壳的类型没有被识别出来,Vc 6.0倒是识别出来了,Vc 6.0的特征是 入口函数先调用GetVersion() 2 用OD找OEP 拖进O ...
- 【iOS】iOS Error Domain=NSCocoaErrorDomain Code=3840 "未能完成操作。(“Cocoa”错误 3840。)"
昨天遇到的这个问题,详细信息: ----->类和方法__25+[Manager noticeRequest:]_block_invoke399----->错误信息Error Domain= ...
- BME200加密网关,在电力与工业应用的加密网关设计与介绍
加密通信网关,顾名思义就是带加密的通信网关终端, 一般业内主是需用到是工业通信关行业的为主的.,BME200加密通信网关,主要电力和工业互联网相关领域开发的一款加密通信网关. 为什么出现加密网关 1 ...
- python协程详解
目录 python协程详解 一.什么是协程 二.了解协程的过程 1.yield工作原理 2.预激协程的装饰器 3.终止协程和异常处理 4.让协程返回值 5.yield from的使用 6.yield ...
- 注解与AOP切面编程实现redis缓存与数据库查询的解耦
一般缓存与数据库的配合使用是这样的. 1.查询缓存中是否有数据. 2.缓存中无数据,查询数据库. 3.把数据库数据插入到缓存中. 其实我们发现 1,3 都是固定的套路,只有2 是真正的业务代码.我们可 ...
- 从JavaScript到Python之异常
不少前端工程师看到这个标题可能会产生质问: 我js用得好好的,能后端能APP,为什么还要学习Python? 至少有下面两个理由: 学习曲线.ES6之后的JavaScript(TypeScript)的在 ...