HDU/HDOJ 2063 过山车(二分图最大匹配,vector的使用)

2023-12-13 19:58

本文主要是介绍HDU/HDOJ 2063 过山车(二分图最大匹配,vector的使用),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://acm.split.hdu.edu.cn/showproblem.php?pid=2063

过山车

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 18847    Accepted Submission(s): 8230


Problem Description
RPG girls今天和大家一起去游乐场玩,终于可以坐上梦寐以求的过山车了。可是,过山车的每一排只有两个座位,而且还有条不成文的规矩,就是每个女生必须找个个男生做partner和她同坐。但是,每个女孩都有各自的想法,举个例子把,Rabbit只愿意和XHD或PQK做partner,Grass只愿意和linle或LL做partner,PrincessSnow愿意和水域浪子或伪酷儿做partner。考虑到经费问题,boss刘决定只让找到partner的人去坐过山车,其他的人,嘿嘿,就站在下面看着吧。聪明的Acmer,你可以帮忙算算最多有多少对组合可以坐上过山车吗?

Input
输入数据的第一行是三个整数K , M , N,分别表示可能的组合数目,女生的人数,男生的人数。0<K<=1000
1<=N 和M<=500.接下来的K行,每行有两个数,分别表示女生Ai愿意和男生Bj做partner。最后一个0结束输入。

Output
对于每组数据,输出一个整数,表示可以坐上过山车的最多组合数。

Sample Input
  
6 3 3 1 1 1 2 1 3 2 1 2 3 3 1 0

Sample Output
  
3

Author
PrincessSnow

Source
RPG专场练习赛  

题意:

裸裸地二分图模板,上次敲匈牙利是什么时候都不记得了......

二维数组的模板都差点忘记了!

第二次使用 vector ,宇神说很强大的一个容器。童鞋也不会 vector ? 点击这里参考学下!

问题卡在如下:

for(int j=0; j<=Vec[gril].size(); j++) {//遍历男生
应该是
j<Vec[gril].size()
最基础的都被忽略了,也怪自己有点懒,直接修改的是二维数组的代码!


Code:vector 实现

降低空间复杂度

#include<stdio.h>
#include<cstring>
#include<vector>
using namespace std;
const int MYDD=1103;
const int MAXN=512;vector<int> Vec[MYDD];//创建一个容器 
int Link[MYDD];//记录和当前男生 j 在一起的女生 Link[j]
bool Vis[MYDD];//记录男生 j 已经有无伙伴的状态bool HK(int gril) {for(int j=0; j<Vec[gril].size(); j++) {//遍历该女生要求的男生int v=Vec[gril][j];if(!Vis[v]) {Vis[v]=true;if(Link[v]==-1||HK(Link[v])) {// *wa_bug HK(v)Link[v]=gril;//当前女生和男生 j 在一组return true;}}}return false;
}int main() {int k;while(scanf("%d",&k)&&k) {int m,n;scanf("%d%d",&m,&n);for(int j=0; j<MAXN; j++)Vec[j].clear();//容器的清空即初始化for(int j=0; j<k; j++) {int gril,boy;scanf("%d%d",&gril,&boy);Vec[gril].push_back(boy);//gril 尾部加入一个中意的 boy}/***匈牙利算法****/int ans=0;memset(Link,-1,sizeof(Link));for(int j=1; j<=m; j++) {//遍历女生memset(Vis,false,sizeof(Vis));if(HK(j))	ans++;}printf("%d\n",ans);}return 0;
}



Code:二维数组实现

#include<stdio.h>
#include<cstring>
const int MYDD=1103;
const int MAXN=512;bool Map[MAXN][MAXN];//记录女生 i和男生 j 在一组
int Link[MYDD];//记录和当前男生 j 在一起的女生 Link[j]
bool Vis[MYDD];//记录男生 j 的伙伴状态bool HK(int gril,int n) {for(int i=1; i<=n; i++) {//遍历男生if(!Vis[i]&&Map[gril][i]) {Vis[i]=true;if(Link[i]==-1||HK(Link[i],n)) {Link[i]=gril;//当前女生和男生 i 在一组return true;}}}return false;
}int main() {int k;while(scanf("%d",&k)&&k) {int m,n;scanf("%d%d",&m,&n);memset(Map,false,sizeof(Map));for(int j=0; j<k; j++) {int gril,boy;scanf("%d%d",&gril,&boy);Map[gril][boy]=true;}/***匈牙利算法****/int ans=0;memset(Link,-1,sizeof(Link));for(int j=1; j<=m; j++) {//遍历女生memset(Vis,false,sizeof(Vis));// *wa_bug 不能够使用 if(Link[j]==-1)if(HK(j,n))	ans++;}printf("%d\n",ans);}return 0;
}
/* By : Shyazhut */


这篇关于HDU/HDOJ 2063 过山车(二分图最大匹配,vector的使用)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/489766

相关文章

使用Redis快速实现共享Session登录的详细步骤

《使用Redis快速实现共享Session登录的详细步骤》在Web开发中,Session通常用于存储用户的会话信息,允许用户在多个页面之间保持登录状态,Redis是一个开源的高性能键值数据库,广泛用于... 目录前言实现原理:步骤:使用Redis实现共享Session登录1. 引入Redis依赖2. 配置R

使用Python的requests库调用API接口的详细步骤

《使用Python的requests库调用API接口的详细步骤》使用Python的requests库调用API接口是开发中最常用的方式之一,它简化了HTTP请求的处理流程,以下是详细步骤和实战示例,涵... 目录一、准备工作:安装 requests 库二、基本调用流程(以 RESTful API 为例)1.

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

Python yield与yield from的简单使用方式

《Pythonyield与yieldfrom的简单使用方式》生成器通过yield定义,可在处理I/O时暂停执行并返回部分结果,待其他任务完成后继续,yieldfrom用于将一个生成器的值传递给另一... 目录python yield与yield from的使用代码结构总结Python yield与yield

Go语言使用select监听多个channel的示例详解

《Go语言使用select监听多个channel的示例详解》本文将聚焦Go并发中的一个强力工具,select,这篇文章将通过实际案例学习如何优雅地监听多个Channel,实现多任务处理、超时控制和非阻... 目录一、前言:为什么要使用select二、实战目标三、案例代码:监听两个任务结果和超时四、运行示例五

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3