[bzoj1191]超级英雄hero<二分图匹配*匈牙利算法>
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1191
今天随便在bzoj找了一题做,题一读完就发现是个匈牙利算法的裸题,原本以为可以一次过的,结果WA了不下五次,深感羞愧,后来我改变了方法,没有用邻接链表,改用邻接矩阵,结果一下子就过了,这让我甚是懵逼,到现在都没搞明白我的邻接链表哪里错了
-------------PS:最后把编号改回了0~n-1就过了
这道题纯粹是裸题,没有一丝思想上的难度,但是我自己小小处理了一个地方,这个地方处理或不处理不会影响最后的答案,就是我把锦囊标号0~n-1全部加1变成了1~n(PS:强迫症而已,不影响答案)【其实好像是有错误的】
首先来看看我的邻接链表方法吧
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<cstdlib>
#include<cmath>
#include<queue>
#define maxn 2005
using namespace std; struct edge{
int u,v,nxt;
}e[maxn<<]; int vis[maxn],att[maxn],head[maxn];
int n,m,ans; int pos=;
void adde(int u,int v)
{
e[pos].u=u;
e[pos].v=v;
e[pos].nxt=head[u];
head[u]=pos++;
} bool can(int x)
{
for(int i=head[x];i!=-;i=e[i].nxt)
{
int v=e[i].v;
if(vis[v]==)
{
vis[v]=;
if(can(att[v])||!att[v])
{
att[v]=x;
return ;
}
}
}
return ;
} int main()
{
memset(att,,sizeof(att));
memset(head,-,sizeof(head));
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++)
{
int a,b;
scanf("%d%d",&a,&b);
if(a!=b)
{
adde(i,a);
adde(i,b);
}else adde(i,a);
}
for(int i=;i<=m;i++)
{
memset(vis,,sizeof(vis));
if(can(i))ans++;
else break;
}
cout<<ans;
}
然后就是我更改后的邻接矩阵,这个代码倒是一次过了,不过就让我瞬间懵逼(链表哪错了????)
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<cstdlib>
#include<cmath>
#include<queue>
#define maxn 1005
using namespace std; int map[maxn][maxn];
int vis[maxn],att[maxn];
int n,m,ans; bool can(int x)
{
for(int i=;i<=n;i++)
{
if(map[x][i]==&&vis[i]==)
{
vis[i]=;
if(!att[i]||can(att[i]))
{
att[i]=x;
return ;
}
} }
return ;
} int main()
{
memset(att,,sizeof(att));
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++)
{
int a,b;
scanf("%d%d",&a,&b);
map[i][a+]=;map[i][b+]=;
}
for(int i=;i<=m;i++)
{
memset(vis,,sizeof(vis));
if(can(i))ans++;
else break;
}
cout<<ans;
}
PS:链表的问题还望各位大佬发现问题并指出一下Orz
[bzoj1191]超级英雄hero<二分图匹配*匈牙利算法>的更多相关文章
- [BZOJ1191]超级英雄Hero
		Description 现在电视台有一种节目叫做超级英雄,大概的流程就是每位选手到台上回答主持人的几个问题,然后根据回答问题的 多少获得不同数目的奖品或奖金.主持人问题准备了若干道题目,只有当选手正确 ... 
- BZOJ1191 超级英雄Hero (匈牙利算法)
		直接跑匈牙利,注意到“只有当选手正确回答一道题后,才能进入下一题,否则就被淘汰”,一旦无法满足就直接退出. #include <cstdio> #include <algorithm ... 
- [BZOJ1191][HNOI2006]超级英雄Hero  类似二分图的最大匹配
		1191: [HNOI2006]超级英雄Hero Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4740 Solved: 2162[Submit][ ... 
- BZOJ 1191 超级英雄 Hero 题解
		BZOJ 1191 超级英雄 Hero 题解 Description 现在电视台有一种节目叫做超级英雄,大概的流程就是每位选手到台上回答主持人的几个问题,然后根据回答问题的多少获得不同数目的奖品或奖金 ... 
- bzoj 1191: [HNOI2006]超级英雄Hero
		1191: [HNOI2006]超级英雄Hero Time Limit: 10 Sec Memory Limit: 162 MB 二分图匹配... Description 现在电视台有一种节目叫做超 ... 
- BZOJ 1191: [HNOI2006]超级英雄Hero  二分匹配
		1191: [HNOI2006]超级英雄Hero Description 现在电视台有一种节目叫做超级英雄,大概的流程就是每位选手到台上回答主持人的几个问题,然后根据回答问题的多少获得不同数目的奖品或 ... 
- bzoj 1191: [HNOI2006]超级英雄Hero 并查集 || 匈牙利算法
		1191: [HNOI2006]超级英雄Hero Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1804 Solved: 850[Submit][S ... 
- bzoj 1191 [HNOI2006]超级英雄Hero(最大基数匹配)
		1191: [HNOI2006]超级英雄Hero Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2813 Solved: 1331[Submit][ ... 
- BZOJ 1191: [HNOI2006]超级英雄Hero(二分图匹配)
		云神说他二分图匹配从来都是用网络流水过去的...我要发扬他的精神.. 这道题明显是二分图匹配.网络流的话可以二分答案+最大流.虽然跑得很慢.... -------------------------- ... 
随机推荐
- 002-DOM事件实例-实现一个可以拖拽的登陆窗口
			前言:这是跟着慕课网一个老师的视频做的,这几天在重新的梳理自己,写完这个例子要系统的学一下jQuery,我司现在用的还是比较多,毕竟用了它不用考虑IE兼容性,可以让开发更有效率. 1.项目需求及基本的 ... 
- Levenshtein Distance(编辑距离)算法与使用场景
			前提 已经很久没深入研究过算法相关的东西,毕竟日常少用,就算死记硬背也是没有实施场景导致容易淡忘.最近在做一个脱敏数据和明文数据匹配的需求的时候,用到了一个算法叫Levenshtein Distanc ... 
- 峰哥说技术:08-Spring Boot整合FreeMarker视图
			Spring Boot深度课程系列 峰哥说技术—2020庚子年重磅推出.战胜病毒.我们在行动 08 峰哥说技术:Spring Boot整合FreeMarker视图 前面带着大家整合了Thymelea ... 
- 《即时消息技术剖析与实战》学习笔记12——IM系统如何提升图片、音视频消息发送、浏览的体验
			IM系统如何提升用户发送.浏览图片和音视频消息的体验呢?一是保证图片.音视频消息发送得又快又稳,二是保证用户浏览播放图片.音视频消息时流畅不卡顿. 一.提升用户发送图片.音视频的体验 1. 多上传接入 ... 
- Python - 常用内置变量
			直接上代码 #!/usr/bin/env python # -*- coding: utf-8 -*- """ 这是注释__doc__会打印这部分内容 "&qu ... 
- js 碰撞+拖拽
			<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ... 
- GO系列 | 5分钟入门GO【译】
			什么是Google Go? Google Go是由Robert Griesmer,Rob Pike和Ken Thompson在Google设计的一种开源编程语言. Go在语法上类似于C语言: 除了内存 ... 
- 玩转控件:重写/重绘Dev中MessageBox弹窗控件
			很久没有更新博客了,本想着直接发一篇<手撕ERP>系列,从控件重写.重绘,到框架搭建,再到部分模块实现+业务的.但是每次动手的时候,都觉得难以下手.直接从数据库设计开始吧,模块设计还没定下 ... 
- ssh 公钥 下载选择的时候 下拉选择 ssh 然后 git clone
			ssh 公钥 下载选择的时候 下拉选择 ssh 然后 git clone 
- SpringBoot图文教程17—上手就会 RestTemplate 使用指南「Get Post」「设置请求头」
			有天上飞的概念,就要有落地的实现 概念十遍不如代码一遍,朋友,希望你把文中所有的代码案例都敲一遍 先赞后看,养成习惯 SpringBoot 图文教程系列文章目录 SpringBoot图文教程1-Spr ... 
