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

相关文章

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa