热门标签 | 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



推荐阅读
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 在现代Web应用中,当用户滚动到页面底部时,自动加载更多内容的功能变得越来越普遍。这种无刷新加载技术不仅提升了用户体验,还优化了页面性能。本文将探讨如何实现这一功能,并介绍一些实际应用案例。 ... [详细]
  • 本文深入探讨了POJ2762问题,旨在通过强连通分量缩点和单向连通性的判断方法,解决有向图中任意两点之间的可达性问题。文章详细介绍了算法原理、实现步骤,并附带完整的代码示例。 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 本文探讨了如何在iOS开发环境中,特别是在Xcode 6.1中,设置和应用自定义文本样式。我们将详细介绍实现方法,并提供一些实用的技巧。 ... [详细]
  • JavaScript 基础语法指南
    本文详细介绍了 JavaScript 的基础语法,包括变量、数据类型、运算符、语句和函数等内容,旨在为初学者提供全面的入门指导。 ... [详细]
  • 20100423:Fixes:更新批处理,以兼容WIN7。第一次系统地玩QT,于是诞生了此预备式:【QT版本4.6.0&#x ... [详细]
  • 开发笔记:9.八大排序
    开发笔记:9.八大排序 ... [详细]
  • 本文探讨了在使用Selenium进行自动化测试时,由于webdriver对象实例化位置不同而导致浏览器闪退的问题,并提供了详细的代码示例和解决方案。 ... [详细]
  • 解决SVN图标显示异常问题的综合指南
    本文详细探讨了SVN图标无法正常显示的问题,并提供了多种有效的解决方案,涵盖不同环境下的具体操作步骤。通过本文,您将了解如何排查和修复这些常见的SVN图标显示故障。 ... [详细]
  • 本文详细介绍了 org.apache.commons.io.IOCase 类中的 checkCompareTo() 方法,通过多个代码示例展示其在不同场景下的使用方法。 ... [详细]
  • 本文介绍如何在 C++ 中使用链表结构存储和管理数据。通过具体示例,展示了静态链表的基本操作,包括节点的创建、链接及遍历。 ... [详细]
  • 本文探讨了使用C#在SQL Server和Access数据库中批量插入多条数据的性能差异。通过具体代码示例,详细分析了两种数据库的执行效率,并提供了优化建议。 ... [详细]
  • 本问题探讨了在特定条件下排列儿童队伍的方法数量。题目要求计算满足条件的队伍排列总数,并使用递推算法和大数处理技术来解决这一问题。 ... [详细]
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社区 版权所有