博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 2063 过山车 二分图题解
阅读量:5076 次
发布时间:2019-06-12

本文共 1125 字,大约阅读时间需要 3 分钟。

一个男女搭配的关系图,看能够凑成多少对,基本和最原始的一个二分图谜题一样了,就是 一个岛上能够凑成多少对夫妻的问题。

所以是典型的二分图问题。

使用匈牙利算法,写成两个函数,就很清晰了。

本程序还带分配释放程序,当然oj一般不须要。可是好的程序一定要。

#include 
#include
int K, M, N, a, b;int *linker;bool **gra, *used;void initGraph(){ gra = (bool **) malloc(M * sizeof(bool*));//注意是bool*不是bool for (int i = 1; i < M; i++) gra[i] = (bool *) calloc(N, sizeof(bool));}void freeGraph(){ for (int i = 1; i < M; i++) free(gra[i]); free(gra);}bool hunDFS(int u){ for (int v = 1; v < N; v++) { if (gra[u][v] && !used[v]) { used[v] = true; if (!linker[v] || hunDFS(linker[v])) { linker[v] = u; return true; } } } return false;}int hungary(){ int ans = 0; linker = (int *) calloc(N, sizeof(int)); for (int i = 1; i < M; i++) { used = (bool *) calloc(N, sizeof(bool)); if (hunDFS(i)) ans++; free(used); } free(linker); return ans;}int main(){ while (scanf("%d %d %d", &K, &M, &N) != EOF && K) { M++, N++;//下标从1開始,0不使用 initGraph(); while (K--) { scanf("%d %d", &a, &b); gra[a][b] = true; } printf("%d\n", hungary()); freeGraph(); } return 0;}

转载于:https://www.cnblogs.com/zfyouxi/p/4297643.html

你可能感兴趣的文章
oracle连接的三个配置文件(转)
查看>>
Python内置函数(29)——help
查看>>
Android TextView加上阴影效果
查看>>
《梦断代码》读书笔记(三)
查看>>
Java8 Lambda表达应用 -- 单线程游戏server+异步数据库操作
查看>>
AngularJS学习篇(一)
查看>>
关于Xshell无法连接centos6.4的问题
查看>>
spring security 11种过滤器介绍
查看>>
代码实现导航栏分割线
查看>>
大数据学习系列(8)-- WordCount+Block+Split+Shuffle+Map+Reduce技术详解
查看>>
luogu4849 寻找宝藏 (cdq分治+dp)
查看>>
关于源程序到可运行程序的过程
查看>>
C# Async与Await的使用
查看>>
Mysql性能调优
查看>>
iOS基础-UIKit框架-多控制器管理-实例:qq界面框架
查看>>
自定义tabbar(纯代码)
查看>>
小程序底部导航栏
查看>>
poj1611 简单并查集
查看>>
Ubuntu 14.04下安装CUDA8.0
查看>>
跨平台开发 -- C# 使用 C/C++ 生成的动态链接库
查看>>