scau 8616 汽车拉力比赛
上次我们过了二分图的最佳匹配,现在我们看一道题目,经典的二分图的最佳匹配题目
8616 汽车拉力比赛
时间限制:500MS 内存限制:1000K
提交次数:71 通过次数:24
题型: 编程题 语言: G++;GCC
Description
SCAU车队要去参加汽车拉力比赛啦。拉力比赛中,每辆汽车需要一个驾驶员和一个导航员。SCAU车队一共有有N个驾驶员和N个导航员,每个 驾驶员对每个导航员有一个默契值,现在需要求得某种N对N的配对,使得这N个配对的默契值之和最大。
输入格式
多Case,每一个Case第一行是一个整数N,范围是(1<=N<=16)。接下来有N行,每行有N个数,第i行第j个数表示第i个驾驶员和第j个导航员的默契值。 测试数据会有多组,当N=0时表示数据结束,这行不用处理。
输出格式
输出配对后默契值之和的最大值。
输入样例
1
5
2
10 20
25 5
0
输出样例
5
45
至于如何做,我就不说了,看看我以前的博客吧,思路应该很清晰的
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define inf 99999
//保存一个我们认为的无穷大
int n;
int match[];//表示这个[驾驶员]搭配那个驾驶员
int e[][];//用来保存一张图,表示i-->j的默契值
int vx[];//用来表示 驾驶员 来找过partner
int vy[];//用来表示 导航员 被邀请过搭配
int fx[];//一开始是用来表示每一个驾驶员与1--n个导航员的max,但是随着程序执行,会变化哦
int fy[];//一开始是0的。我们称这两个东西为 标干
int dfs (int u)//我要来找u的partner
{
vx[u]=;//u已经来找过partner啦,标记一下先,待会的km算法需要
int i;
for (i=;i<=n;i++)//筛选n个 导航员 可以知道,驾驶员比较“主动”
{
if (vy[i]==&&fx[u]+fy[i]==e[u][i])//这个导航员没有被邀请过..导航员为u
//驾驶员和导航员的【标杠】值相加,有这个默契值的话,这样选出来的是最优的
{
//vy[i]==1;//这个导航员被邀请过了,但是,接不接受?还是另外一回事
//不是等于等于
//因为他还可能是被别人搭配了嘛
vy[i]=;
if (match[i]==||dfs(match[i]))//如果他没被人搭配了或者,它可以找其他人搭配
{
match[i]=u;//i搭配u 改变条件的
//意思就是导航员i和驾驶员u搭配
return ;//搭配成功
}
}
}
return ;//我找不到啊,后面,就会执行km
}
void do_km()//km算法
//对每一个在vx[]数组中的驾驶员,我们对他进行操作
//操作对象是每一个不在vy[]数组中的导航员,在了的导航员是不能动的,是当前的最优解
{
int i,j;
int d;//表示默契值减小得最多,就是,搭配最大
d=inf;//认为他是无限大
for (i=;i<=n;i++)//遍历每一个驾驶员
{
if (vx[i]==)//表示他是遍历过的
{
for (j=;j<=n;j++)//对他进行遍历导航员
{
if (!vy[j])//没有vy过的导航员才操作
{
if (d>(fx[i]+fy[j]-e[i][j]))//对于后面没vy的导航员,选出最小差值
{
d=fx[i]+fy[j]-e[i][j];
//printf ("%d\n",d);
}
}
}
}
}
//对于每一个vx[]的 fx[] 减去d
//对于每一个vy[]的 fy[] 加上d
//这样,总值会减小哦,就是,我们有机会加入新的导航员,留下空位
for (i=;i<=n;i++)
{
if (vx[i]==)
{
fx[i] -= d;
vx[i]=;//请0
}
if (vy[i]==)//是访问过的哦
{
fy[i] += d;
vy[i]=;//情0
}
}
return ;
}
void work ()
{
int i,j;
memset (e,,sizeof(e));
memset (vx,,sizeof(vx));
memset (vy,,sizeof(vy));
memset (fx,,sizeof(fx));
memset (fy,,sizeof(fy));
memset (match,,sizeof(match)); for (i=;i<=n;i++)
{
for (j=;j<=n;j++)
{
scanf ("%d",&e[i][j]);//不是无向图哦,有向的
//就是e[i][j]!=e[j][i] 有可能相等
}
}
//km算法的一部分,先初始化fx,fy
for (i=;i<=n;i++)//遍历每一个驾驶员
{
fy[i]=;
fx[i]= -inf;//无穷小
for (j=;j<=n;j++)//遍历每一个导航员
{
if (fx[i]<e[i][j])//默契值
{
fx[i]=e[i][j];
}
}
}
for (i=;i<=n;i++)//遍历每一个驾驶员
{
memset (vx,,sizeof(vx));//每一个驾驶员都是新的开始
memset (vy,,sizeof(vy));//要清零,
while (!dfs(i))//如果他找不到搭配,就实现km算法
{
do_km();//km完后,还是会对这个想插入的节点进行dfs的,因为他还没搭配成功嘛
}
}
//进行计数
//现在match[i]记录的是[导航员i]和[驾驶员match[i]]搭配
int ans=;
for (i=;i<=n;i++)//遍历导航员
{
ans += e[match[i]][i];//输入的第一个是驾驶员,第二个是导航员
}
printf ("%d\n",ans);
return ;
}
int main ()
{
while (scanf ("%d",&n)!=EOF && n)
{
work ();
}
return ;
}
scau 8616 汽车拉力比赛的更多相关文章
- 洛谷——P2658 汽车拉力比赛
P2658 汽车拉力比赛 题目描述 博艾市将要举行一场汽车拉力比赛. 赛场凹凸不平,所以被描述为M*N的网格来表示海拔高度(1≤ M,N ≤500),每个单元格的海拔范围在0到10^9之间. 其中一些 ...
- P2658 汽车拉力比赛
题目描述 博艾市将要举行一场汽车拉力比赛. 赛场凹凸不平,所以被描述为M*N的网格来表示海拔高度(1≤ M,N ≤500),每个单元格的海拔范围在0到10^9之间. 其中一些单元格被定义为路标.组织者 ...
- 洛谷—— P2658 汽车拉力比赛
https://www.luogu.org/problem/show?pid=2658 题目描述 博艾市将要举行一场汽车拉力比赛. 赛场凹凸不平,所以被描述为M*N的网格来表示海拔高度(1≤ M,N ...
- 洛谷 P2658 汽车拉力比赛
题目传送门 解题思路: 二分答案,然后bfs验证,如果从一个路标可以达到其它所有路标,则答案可行.知道找到最佳答案. AC代码: #include<iostream> #include&l ...
- 汽车制造商表态:必须依靠MES系统来管控流程
汽车行业特点 汽车工业是一个高投入,高产出,集群式发展的产业部门. 汽车自身的投资,生产,研发,供应,销售,维修:前序的原材料,零部件,技术装备,物流:后序的油料,服务,信贷,咨询,保险,直至基础设施 ...
- New Concept English Two 22 58
$课文56 比声音还快! 579. Once a year, a race is held for old cars. 旧式汽车的比赛每年举行一次. 580. A lot of cars enter ...
- [SD心灵鸡汤]003.每月一则 - 2015.07
乔布斯去世了,但他留给世人的财富却很多,值得每个人学习.他是个精力充沛魅力无限的家伙,同时也是一个很会鼓动人心的激励大师,甚至在他的平常对话中,经典的语句也常常脱口而出. 这里摘取了一些他的经典语录, ...
- 【题解】Leyni的汽车比赛
[题解]Leyni的汽车比赛 HRBUST - 1404 思维题?居然被我凑出来了 这种图论题先设这样一个状态 \[ ans(i,j,f) \] 表示从i到j,最多使用f个交通工具的最短路 转移的话, ...
- HLG 1400 汽车比赛
题目链接:http://acm.hrbust.edu.cn/index.php?m=ProblemSet&a=showProblem&problem_id=1400 结构体排序+树状数 ...
随机推荐
- 【转】 Pro Android学习笔记(四二):Fragment(7):切换效果
目录(?)[-] 利用setTransition 利用setCustomAnimations 通过ObjectAnimator自定义动态效果 程序代码的编写 利用fragment transactio ...
- redhat无法注册RHN的解决办法
1.问题 初学Linux,采用边实战nginx边学Linux命令的方式,这样学习的还快还真实一些.当然,问题来的很快.我使用的是redhat,安装pcre就出现了问题,如下: [root@localh ...
- C++模板特化编程
在C++中,模板特化是除了类之外的一种封装变化的方法.模板特化可以通过编译器来对不同的模板参数生成不同的代码. 模板特化通常以模板结构体作为载体.常用技法包括:类型定义.静态成员常量定义和静态成员函数 ...
- 2.Apache + Tomcat + mod_jk实现集群服务
转自:http://www.cnblogs.com/dennisit/p/3370220.html Tomcat中的集群原理是通过组播的方式进行节点的查找并使用TCP连接进行会话的复制. 实现效果:用 ...
- 关于UI性能优化
1.使用已经有的VIEW,而不是每次都去新生成一个 2.创建自定义类来进行组件和数据的缓存,在下一次调用的时候直接从FLAG中取出 3.分页,预加载 使用VIEWSTUB进行调用时加载 VIEWSTU ...
- Learning Python 008 正则表达式-003 search()方法
Python 正则表达式 - search()方法 findall()方法在找到第一个匹配之后,还会继续找下去,findall吗,就是找到所有的匹配的意思.如果你只是想找到第一个匹配的信息后,就不在继 ...
- pig 入门教程(1)
出处:http://www.codelast.com/ 本文可以让刚接触pig的人对一些基础概念有个初步的了解. 本文大概是互联网上第一篇公开发表的且涵盖大量实际例子的Apache Pig中文教程(由 ...
- rlwrap:让控制台程序使用input.rc里的设置
习惯了vi模式,在bash里配置input.rc可以使平时命令行操作都使用vi习惯,翻页和跳动光标都很方便 但是当运行一些交互式程序时,比如redis-cli,lua等,它们却不按input.rc的配 ...
- 8、SRR数据下载https://ftp-trace.ncbi.nlm.nih.gov/sra/sdk/2.8.2/
1.prefetch SRRxxxxxx -/ncbi/public/sra 2.fastq-dump --split-files xxxxxxsra 3.SRA.SAM以及Fastq ...
- 7、linux常见系统环境变量
使用env命令显示所有环境变量 env (常见的有HOSTNAME,SHELL,HISTSIZE,PERL5LIB,USER,PATH,PWD,LANG,HOME, LD_LIBRARY_PATH ...