HDU 2063 过山车(匈牙利算法模板)

2023-12-10 04:32

本文主要是介绍HDU 2063 过山车(匈牙利算法模板),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

链接:

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


分析与总结:

这题是裸的二分匹配,用来验证模板的


代码:

1.  DFS

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int MAXN = 505;
int Nx,Ny;  
int G[MAXN][MAXN];
int Mx[MAXN], My[MAXN];  
bool mark[MAXN];bool FindPath(int u){for(int v=0; v<Ny; ++v){if(G[u][v] && !mark[v]){mark[v] = true;if(My[v]==-1 || FindPath(My[v])){My[v] = u;Mx[u] = v;return true;}}}return false;
}
int MaxMatch(){int ret=0;memset(Mx, -1, sizeof(Mx));memset(My, -1, sizeof(My));for(int u=0; u<Nx; ++u){if(Mx[u] == -1) {memset(mark, 0, sizeof(mark));if(FindPath(u)) ++ret;}}return ret;
}int main(){int k,a,b;while(~scanf("%d%d%d",&k,&Nx,&Ny) && k){memset(G,0,sizeof(G));for(int i=0; i<k; ++i) {scanf("%d%d",&a,&b);G[a-1][b-1]=1;}printf("%d\n",MaxMatch());}return 0;
}


2. BFS

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int MAXN = 505;
int Nx,Ny;  
int G[MAXN][MAXN];
int Mx[MAXN], My[MAXN], prev[MAXN], Q[MAXN];  
int mark[MAXN];int MaxMatch(){int res = 0;int front, rear;memset(Mx, -1, sizeof(Mx));memset(My, -1, sizeof(My));memset(mark, -1, sizeof(mark));for (int i = 0; i < Nx; i++){if (Mx[i] == -1){front = rear = 0;Q[rear++] = i;prev[i] = -1;bool flag = 0;while (front < rear && !flag){int u = Q[front];for (int v = 0; v < Ny && !flag; v++){if (G[u][v] && mark[v] != i){mark[v] = i;Q[rear++] = My[v];if (My[v] >= 0)prev[My[v]] = u;else{flag = 1;int d = u, e = v;while (d != -1){int t = Mx[d];Mx[d] = e;My[e] = d;d = prev[d];e = t;}}}}front++;}if (Mx[i] != -1)res++;}}return res;
}
int main(){int k,a,b;while(~scanf("%d%d%d",&k,&Nx,&Ny) && k){memset(G,0,sizeof(G));for(int i=0; i<k; ++i) {scanf("%d%d",&a,&b);G[a-1][b-1]=1;}printf("%d\n",MaxMatch());}return 0;
}





 ——  生命的意义,在于赋予它意义士。

          原创 http://blog.csdn.net/shuangde800 , By   D_Double  (转载请标明)




这篇关于HDU 2063 过山车(匈牙利算法模板)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/476024

相关文章

Java如何根据word模板导出数据

《Java如何根据word模板导出数据》这篇文章主要为大家详细介绍了Java如何实现根据word模板导出数据,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... pom.XML文件导入依赖 <dependency> <groupId>cn.afterturn</groupId>

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

Python中Flask模板的使用与高级技巧详解

《Python中Flask模板的使用与高级技巧详解》在Web开发中,直接将HTML代码写在Python文件中会导致诸多问题,Flask内置了Jinja2模板引擎,完美解决了这些问题,下面我们就来看看F... 目录一、模板渲染基础1.1 为什么需要模板引擎1.2 第一个模板渲染示例1.3 模板渲染原理二、模板

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.