热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

拆点+KM,建图思路看的题解,求解最小权匹配问题

本文介绍了一种求解最小权匹配问题的方法,使用了拆点和KM算法。通过将机器拆成多个点,表示加工的顺序,然后使用KM算法求解最小权匹配,得到最优解。文章给出了具体的代码实现,并提供了一篇题解作为参考。

题目链接

拆点+KM,建图思路看的题解。。。

看懂的题意后,想了好一会。知道这题是KM,但是不会建图,无奈啊。

建图很巧妙,假如同一个机器上加工了k件物品,那么实际花费时间k*a1+(k-1)*a2+(k-3)*a3....

其实对这个拆点,也不是很懂。

这样把m个机器拆成n个点,表示是第几个加工的。套上模版,这题是求最小权,取一下相反数就行了。

拆成两个集合一个存n个物品,另一个存第i个机器上第j个加工。

1 #include
2 #include
3 #include <string>
4 #include
5 #include
6 using namespace std;
7 #define N 2552
8 #define INF 0x7fffffff
9 int mat[N][N];
10 int inx[N],iny[N];
11 int lx[N],ly[N];
12 int match[N];
13 int n,m;
14 int inp[N][N];
15 int dfs(int u)
16 {
17 inx[u] &#61; 1;
18 int i;
19 for(i &#61; 1; i <&#61; m*n; i &#43;&#43;)
20 {
21 if(!iny[i]&&lx[u]&#43;ly[i] &#61;&#61; mat[u][i])
22 {
23 iny[i] &#61; 1;
24 if(match[i] &#61;&#61; -1||dfs(match[i]))
25 {
26 match[i] &#61; u;
27 return 1;
28 }
29 }
30 }
31 return 0;
32 }
33 void KM()
34 {
35 int i,j,k,temp;
36 for(i &#61; 1;i )
37 {
38 lx[i] &#61; -INF;
39 ly[i] &#61; -INF;
40 }
41 for(i &#61; 1; i <&#61; n; i &#43;&#43;)
42 {
43 for(j &#61; 1; j <&#61; m*n; j &#43;&#43;)
44 lx[i] &#61; max(lx[i],mat[i][j]);
45 }
46 for(i &#61; 1; i <&#61; n; i &#43;&#43;)
47 {
48 for(;;)
49 {
50 memset(inx,0,sizeof(inx));
51 memset(iny,0,sizeof(iny));
52 if(dfs(i))
53 break;
54 else
55 {
56 temp &#61; INF;
57 for(j &#61; 1; j <&#61; n; j &#43;&#43;)
58 {
59 if(inx[j])
60 {
61 for(k &#61; 1; k <&#61; m*n; k &#43;&#43;)
62 {
63 if(!iny[k]&&temp > lx[j]&#43;ly[k]-mat[j][k])
64 temp &#61; lx[j]&#43;ly[k]-mat[j][k];
65 }
66 }
67 }
68 for(j &#61; 1;j <&#61; n;j &#43;&#43;)
69 {
70 if(inx[j])
71 lx[j] -&#61; temp;
72 }
73 for(j &#61; 1;j <&#61; m*n;j &#43;&#43;)
74 {
75 if(iny[j])
76 ly[j] &#43;&#61; temp;
77 }
78 }
79 }
80 }
81 }
82 int main()
83 {
84 int i,j,k,cas;
85 scanf("%d",&cas);
86 while(cas--)
87 {
88 scanf("%d%d",&n,&m);
89 memset(match,-1,sizeof(match));
90 for(i &#61; 1;i <&#61; n;i &#43;&#43;)
91 {
92 for(j &#61; 1;j <&#61; m;j &#43;&#43;)
93 {
94 scanf("%d",&inp[i][j]);
95 }
96 }
97 for(i &#61; 1;i <&#61; n;i &#43;&#43;)
98 {
99 for(j &#61; 1;j <&#61; m;j &#43;&#43;)
100 {
101 for(k &#61; 1;k <&#61; n;k &#43;&#43;)
102 {
103 mat[i][(j-1)*n&#43;k] &#61; -((n-k&#43;1)*inp[i][j]);
104 }
105 }
106 }
107 KM();
108 int ans &#61; 0;
109 for(i &#61; 1;i <&#61; n*m;i &#43;&#43;)
110 {
111 if(match[i] !&#61; -1)
112 ans &#43;&#61; mat[match[i]][i];
113 }
114 printf("%.6lf\n",-ans*1.0/n);
115 }
116 return 0;
117 }

 

转:https://www.cnblogs.com/naix-x/archive/2013/04/17/3027096.html



推荐阅读
  • 题目概述:Sereja 拥有一个由 n 个整数组成的数组 a1, a2, ..., an。他计划执行 m 项操作,这些操作包括更新数组中的特定元素、增加数组中所有元素的值,以及查询数组中的特定元素。 ... [详细]
  • 题目描述:Balala Power! 时间限制:4000/2000 MS (Java/Other) 内存限制:131072/131072 K (Java/Other)。题目背景及问题描述详见正文。 ... [详细]
  • 本文介绍了使用Python和C语言编写程序来计算一个给定数值的平方根的方法。通过迭代算法,我们能够精确地得到所需的结果。 ... [详细]
  • Hanks博士是一位著名的生物技术专家,他的儿子Hankson对数学有着浓厚的兴趣。最近,Hankson遇到了一个有趣的数学问题,涉及求解特定条件下的正整数x,而不使用传统的辗转相除法。 ... [详细]
  • 吴石访谈:腾讯安全科恩实验室如何引领物联网安全研究
    腾讯安全科恩实验室曾两次成功破解特斯拉自动驾驶系统,并远程控制汽车,展示了其在汽车安全领域的强大实力。近日,该实验室负责人吴石接受了InfoQ的专访,详细介绍了团队未来的重点方向——物联网安全。 ... [详细]
  • 网络流24题——试题库问题
    题目描述:假设一个试题库中有n道试题。每道试题都标明了所属类别。同一道题可能有多个类别属性。现要从题库中抽取m道题组成试卷。并要求试卷包含指定类型的试题。试设计一个满足要求的组卷算 ... [详细]
  • 如何高效学习鸿蒙操作系统:开发者指南
    本文探讨了开发者如何更有效地学习鸿蒙操作系统,提供了来自行业专家的建议,包括系统化学习方法、职业规划建议以及具体的开发技巧。 ... [详细]
  • Excel技巧:单元格中显示公式而非结果的解决方法
    本文探讨了在Excel中如何通过简单的方法解决单元格显示公式而非计算结果的问题,包括使用快捷键和调整单元格格式两种方法。 ... [详细]
  • 本文针对HDU 1042 N! 问题提供详细的解析和代码实现。题目要求计算给定整数N(0 ≤ N ≤ 10000)的阶乘N!。文章不仅提供了算法思路,还附上了C++语言的具体实现。 ... [详细]
  • 编程解析:CF989C 花朵之雾 (构造算法)
    本文深入探讨了CF989C '花朵之雾'问题的构造算法,提供了详细的解题思路和代码实现。 ... [详细]
  • 探讨了一个包含纯虚函数的C++代码片段,分析了其中的语法错误及逻辑问题,并提出了修正方案。 ... [详细]
  • 本文详细介绍了如何在 Ubuntu 14.04 系统上搭建仅使用 CPU 的 Caffe 深度学习框架,包括环境准备、依赖安装及编译过程。 ... [详细]
  • 本文详细介绍如何在 Apache 中设置虚拟主机,包括基本配置和高级设置,帮助用户更好地理解和使用虚拟主机功能。 ... [详细]
  • 本文详细介绍了如何在最新版本的Xcode中重命名iOS项目,包括项目名称、应用名称及相关的文件夹和配置文件。通过本文,开发者可以轻松完成项目的重命名工作。 ... [详细]
  • hlg_oj_1116_选美大赛这题是最长子序列,然后再求出路径就可以了。开始写的比较乱,用数组什么的,后来用了指针就好办了。现在把代码贴 ... [详细]
author-avatar
手机用户随便转转
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有