[HNOI2006]超级英雄

题目描述

现在电视台有一种节目叫做超级英雄,大概的流程就是每位选手到台上回答主持人的几个问题,然后根据回答问题的多少获得不同数目的奖品或奖金。主持人问题准备了若干道题目,只有当选手正确回答一道题后,才能进入下一题,否则就被淘汰。为了增加节目的趣味性并适当降低难度,主持人总提供给选手几个“锦囊妙计”,比如求助现场观众,或者去掉若干个错误答案(选择题)等等。

这里,我们把规则稍微改变一下。假设主持人总共有m道题,选手有n种不同的“锦囊妙计”。主持人规定,每道题都可以从两种“锦囊妙计”中选择一种,而每种“锦囊妙计”只能用一次。我们又假设一道题使用了它允许的锦囊妙计后,就一定能正确回答,顺利进入下一题。现在我来到了节目现场,可是我实在是太笨了,以至于一道题也不会做,每道题只好借助使用“锦囊妙计”来通过。如果我事先就知道了每道题能够使用哪两种“锦囊妙计”,那么你能告诉我怎样选择才能通过最多的题数吗?

输入输出格式

输入格式:

输入的第一行是两个正整数 n 和 m (0<n<1001,0<m<1001)表示总共有 n 种“锦囊妙计”,编号为$ 0∼n−10 \sim n-10∼n−1$,总共有 m 个问题。

以下的m行,每行两个数,分别表示第 m 个问题可以使用的“锦囊妙计”的编号。

注意,每种编号的“锦囊妙计”只能使用一次,同一个问题的两个“锦囊妙计”可能一样。

输出格式:

输出的第一行为最多能通过的题数 p,接下来 p 行,每行为一个整数,第 iii 行表示第 iii 题使用的“锦囊妙计的编号”。

如果有多种答案,那么任意输出一种,本题使用 Special Judge 评判答案。

输入输出样例

输入样例#1:

5 6

3 2

2 0

0 3

0 4

3 2

3 2

输出样例#1:

4

3

2

0

4

思路

二分图最大匹配,不过有一些要注意的地方。

做这道题的应该已经掌握了匈牙利算法了吧,不过不会也没有关系啦。我们看着代码解释


  • 首先,头文件,定义一堆东西,还有建边。
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std; int m;
int n,T;
int x,y;
struct node{
int u,v;
}qwq[105050];
int head[105050],tot=0;
bool vis[105050];
int to[105050];
int ans=0;
int ans_end[105050]; inline void add(int x,int y){
qwq[++tot].u=head[x];
qwq[tot].v=y;
head[x]=tot;
}

  • 第二就是写匈牙利啦。枚举每一条边和要到的点。如果没有标记过,就标记上开始跑。

两种情况

1.它没配对

2.它配对的点可以和别的的点配对

这两种情况成立,我们就配对上,返回一。

inline bool find(int x){
for(int i=head[x];i;i=qwq[i].u){
int v=qwq[i].v;
if(vis[v]==0){
vis[v]=1;
if(!to[v]||find(to[v])==1){//判断
to[v]=x;
ans_end[x]=v;
return 1;
}
}
}
return 0;
}

3.最后就是主函数啦

先是安照题目华丽丽的建边。在直接跑m遍匈牙利就行了

这里有两个坑点。

1.要初始化

2.题目说明“只有当选手正确回答一道题后,才能进入下一题,否则就被淘汰”所以else时就直接break就行QAQ

int main(){
cin>>n>>m;
for(int i=1;i<=m;i++){
cin>>x>>y;
add(i,x);
add(i,y);
}
for(int i=1;i<=m;i++){
memset(vis,0,sizeof(vis));//初始化QAQ超重要
if(find(i)==1){
ans++;
}
else{
break;//只有当选手正确回答一道题后,才能进入下一题,否则就被淘汰
}
}
cout<<ans<<endl;
for(int i=1;i<=ans;i++){
cout<<ans_end[i]<<endl;
}
return 0;
}

完整code

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std; int m;
int n,T;
int x,y;
struct node{
int u,v;
}qwq[105050];
int head[105050],tot=0;
bool vis[105050];
int to[105050];
int ans=0;
int ans_end[105050]; inline void add(int x,int y){
qwq[++tot].u=head[x];
qwq[tot].v=y;
head[x]=tot;
} inline bool find(int x){
for(int i=head[x];i;i=qwq[i].u){
int v=qwq[i].v;
if(vis[v]==0){
vis[v]=1;
if(!to[v]||find(to[v])==1){
to[v]=x;
ans_end[x]=v;
return 1;
}
}
}
return 0;
} int main(){
cin>>n>>m;
for(int i=1;i<=m;i++){
cin>>x>>y;
add(i,x);
add(i,y);
}
for(int i=1;i<=m;i++){
memset(vis,0,sizeof(vis));//初始化QAQ超重要
if(find(i)==1){
ans++;
}
else{
break;//只有当选手正确回答一道题后,才能进入下一题,否则就被淘汰
}
}
cout<<ans<<endl;
for(int i=1;i<=ans;i++){
cout<<ans_end[i]<<endl;
}
return 0;
}

By enceladus

P2319 [HNOI2006]超级英雄 题解的更多相关文章

  1. 洛谷P2319 [HNOI2006]超级英雄 题解

    题目链接: https://www.luogu.org/problemnew/show/P2319 分析 每错,这是一道海南不对是河南呀呀呀错了是湖南的省选题. 但是还是可以作为二分图第二题来练手的, ...

  2. [luogu P2319] [HNOI2006]超级英雄

    [luogu P2319] [HNOI2006]超级英雄 题目描述 现在电视台有一种节目叫做超级英雄,大概的流程就是每位选手到台上回答主持人的几个问题,然后根据回答问题的多少获得不同数目的奖品或奖金. ...

  3. 【luogu P2319 [HNOI2006]超级英雄】 题解

    题目链接:https://www.luogu.org/problemnew/show/P2319 #include <cstdio> #include <cstring> #i ...

  4. 【题解】Luogu P2319 [HNOI2006]超级英雄

    原题传送门 这道题就是一个很简单的二分图匹配 二分图匹配详解 一开始想的是2-sat和网络流,根本没想匈牙利和HK 这道题只要注意一点:当一个点匹配不成功之后就直接退出 剩下的就写个二分图最大匹配就行 ...

  5. 洛谷 P2319 [HNOI2006]超级英雄

    题目描述 题目描述 现在电视台有一种节目叫做超级英雄,大概的流程就是每位选手到台上回答主持人的几个问题,然后根据回答问题的多少获得不同数目的奖品或奖金.主持人问题准备了若干道题目,只有当选手正确回答一 ...

  6. 洛谷P2319 [HNOI2006]超级英雄

    一开始是用二分图匹配(网络流)+二分做的,后来发现直接用匈牙利更简单 #include<cstdio> #include<cstdlib> #include<algori ...

  7. p2319 [HNOI2006]超级英雄

    传送门 分析 从1道m进行匹配,找到第一个不能继续匹配的点即可 代码 #include<iostream> #include<cstdio> #include<cstri ...

  8. BZOJ 1191: [HNOI2006]超级英雄Hero 二分匹配

    1191: [HNOI2006]超级英雄Hero Description 现在电视台有一种节目叫做超级英雄,大概的流程就是每位选手到台上回答主持人的几个问题,然后根据回答问题的多少获得不同数目的奖品或 ...

  9. bzoj 1191: [HNOI2006]超级英雄Hero 并查集 || 匈牙利算法

    1191: [HNOI2006]超级英雄Hero Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1804  Solved: 850[Submit][S ...

随机推荐

  1. UITextView设置占位文字

    这里只介绍一种,这种方便扩展,可以占位文字颜色. 我们继承一个UITextView: #import <UIKit/UIKit.h> @interface MyTextView : UIT ...

  2. NavigationController.viewControllers

      NSMutableArray *viewControllersArray = [NSMutableArray new];    // 获取当前控制器数组    for (CardLoanBaseT ...

  3. Node.js中流程控制

    Node.js中的流程控制可以使用async,在使用之前需要先安装,使用npm安装 npm install async --g 下面主要介绍4种流程控制的方式: 1.串行无关联:async.serie ...

  4. SpringBoot集成freemarker和thymeleaf模板

    1.在MAVEN工程POM.XML中引入依赖架包 <!-- 引入 freemarker 模板依赖 --> <dependency> <groupId>org.spr ...

  5. [SoapUI] 比较两个不同环境下XML格式的Response, 结果不同时设置Test Step的执行状态为失败

    import org.custommonkey.xmlunit.* def responseTP=context.expand( '${Intraday Table_TP#Response}' ) d ...

  6. redis集群部署及常用的操作命令(下)

    搭建好集群之后,为了扩容需要再加入一个节点.那就再复制一个7006,改为相应的redis.conf(复制了改个port就好,如果复制的redis之前属于集群,需要把关联的node.conf之类的去掉) ...

  7. 五)使用 easyui-tabs 遭遇错误 Unexpected Exception caught setting '_' on

    十月 10, 2015 3:08:35 下午 com.opensymphony.xwork2.interceptor.ParametersInterceptor error 严重: Developer ...

  8. MongoDBAppender

    分三步: 1. client 2. appender 3. 配置文件 logback-test.xml <configuration> <appender name="MO ...

  9. Android开发之Tween(补间动画)

    在android中动画主要有三种,①帧动画(http://blog.csdn.net/dmk877/article/details/45893017)这篇文章已经详细的进行了讲解,②补间动画这也是这篇 ...

  10. NIOS II 自定义IP核的静态地址对齐和动态地址对齐

    如果使用静态地址对齐(每个寄存器在Avalon总线上占4个字节的地址)设置IP使用静态地址对齐的方式为,在hw.tcl脚本里加上一局话:set_interface_property as addres ...