(上不了p站我要死了,侵权度娘背锅)
题目大意
有两台机器A和B以及N个需要运行的任务。每台机器有M种不同的模式,而每个任务都恰好在一台机器上运行。如果它在机器A上运行,则机器A需要设置为模式ai,如果它在机器B上运行,则机器B需要设置为模式bi。每台机器上的任务可以按照任意顺序执行,但是每台机器每转换一次模式需要重启一次。请合理为每个任务安排一台机器并合理安排顺序,使得机器重启次数尽量少。
因为自己二分图太差啦。。。所以要做点水题补基础。
每个任务有两个属性,则可以考虑用二分图来做。发现我们想用最少的模式来完成所有任务,所以就是一个最小点覆盖问题。
感性证明一下 最小点覆盖=最大匹配:
当我们跑出最大匹配后,匹配点首先是将匹配边覆盖了(这是肯定的),同时也将其他边覆盖了。如果有边没有覆盖,则其两个端点都没有被选择,那么这条边就又是一个匹配了(哇)。所以选择比最大匹配更多的点是没有意义的,而如果选择的点比最大匹配少,则有匹配边没有覆盖。
所以 最小点覆盖=最大匹配
AC代码(end不能用?!竟然CE?!)
#include<cstdio>
#include<cstring>
#i

这篇博客介绍了如何使用二分图的最小点覆盖解决机器A和B的调度问题,确保任务运行时机器重启次数最少。作者通过感性证明了最小点覆盖等价于最大匹配,并提供了AC代码实现。
最低0.47元/天 解锁文章
1591

被折叠的 条评论
为什么被折叠?



