有垃圾箱,第个垃圾箱包含球。球有种颜色,有球,颜色为。令。
交换是从一个垃圾箱取一个球,然后与另一个垃圾箱交换一个球。我们希望交换的数量最少,以使每个垃圾箱仅包含相同颜色的球。
我对所有都知道一个简单的特殊情况。(如果所有,那么您甚至可以最多交换一次每个球来做到这一点。)
编辑:这是错误的,因为找到是NP困难的。
如果我们知道哪种颜色进入哪个容器,问题就很容易了。
考虑多图,。如果我们知道颜色去仓,然后有平行弧在 IFF斌包含颜色的球。图的每个组成部分都是欧拉。所需的最小交换次数是,其中是覆盖的弧不相交循环的数量。我们可以通过“跟随”欧拉回路进行交换。(使用最小周期的弧进行交换可以将其更改为较小的最小周期和自循环)。一旦整个图形设置了自环,我们就进行了所有必要的交换。
这个问题通常有多难?