我不知道这个问题的名字。下面是我想出的算法。
您需要跟踪剩余的每个块的#个。
repeat:output 1 block of largest color set.output 1 block from the second largest color set.
输出:
rbrbrbrgrbrgrbrgrbr grggy
注意:在运行此算法之前,您需要检查最大颜色集的大小是否大于1 +其他颜色大小的总和。如果是这样,那就没有解决办法。
注意:不需要从第二大集合中进行选择。循环中的第二个选择可以来自任何非最大的颜色集。



