- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
在做一个项目时我遇到了这个问题,我将在这个问题的实际领域之外重新措辞(我想我可以谈论烟花的口径和形状,但这会使理解更加复杂).我正在寻找一种(可能是近似的)算法来解决它。
我有 n 个不同大小的容器,m 个大小不同的对象和 不同的颜色(对象可以是五颜六色的,所以一个物体的颜色确实是一个集合)。
我的目标是将所有物体放入容器中(我已经知道这是可能的),从而最大限度地减少每个容器的颜色多样性。 “颜色的多样性被最小化”是指每个容器中不同颜色的数量之和是最小的。
一个例子。我有两个大小为 2 的容器和四个对象,颜色分别为 {red}、{red, green}、{blue}、{blue, green},每个大小为 1。最佳解决方案是 [{red} , {red, green}], [{blue}, {blue, green}],其中总品种为 2+2=4。更糟糕的解决方案是 [{red}, {blue}], [{red, green}, {blue, green}],其中总多样性为 2+3=5。
我的猜测是这个问题是 NP 难的,因为它听起来比背包问题更难:对象的值被转换为负值,而且还取决于同一容器内的其他对象。但是我不知道如何解决近似解决方案的问题,无论如何这将是非常受欢迎的。
最佳答案
这个问题似乎与 bin-packing problem 有更多共同点而不是背包问题。在knapsack problem ,你只有一个背包可以装满,但它有一个你不能超过的容量。并且您必须在最大化您选择放入的元素的总值(value)的同时做到这一点。在这里,您不必用完所有元素。
但是,在装箱问题中,您有多个箱子,每个箱子都有一个容量。您有兴趣在将每件元素放入某个箱子时尽量减少箱子的数量。您还必须遵守每个箱子的容量限制。与背包不同,在这里您必须用完所有元素。
在您的情况下,您还试图尽量减少箱子的数量,只是它们不能少于两个。而且您还想用完所有对象。您没有对容量限制说太多,但我假设您也必须尊重这一点。到目前为止,它看起来很像装箱问题。您还有一个额外的限制条件:尽量减少每个容器中的颜色数量。
现在,我开始与您分享关于它是 NP-hard 的预感——它具有装箱的所有元素和一个额外的约束。比方说,通过使用一个对象全部为红色的实例,可以很容易地显示从装箱中减少的情况。我们只需要证明 NP 中的问题——即我们可以在多项式时间内验证结果。好了,我们有一个非正式的证明!
这里有一个可能有用的贪心启发法。
表示:不使用集合,考虑长度为 k 的位序列,其中 k 是您拥有的不同颜色的数量。所以,假设你有 3 种颜色——红色、绿色、蓝色。您可以将 [blue] 001、[green, blue] 表示为 011、[red] 表示为 100,等等。
使用比较函数按颜色位序列对项目进行排序,该函数会产生诸如 001、010、100、011、110、111 之类的排序。您可以将这样的比较函数设计为Hamming weight位序列及其实际数值。
请注意,许多颜色模式(位序列)很可能会被许多对象共享。这些对象将在排序列表中显示为连续对象。
遍历排序列表,将具有相同颜色模式的连续项目分配到同一容器。您将从单色变为多色商品。
您以这种方式继续,直到用尽每个箱子的容量。
另一种方法是以相反的顺序开始填充垃圾箱。从具有最多颜色的对象开始。如果可以容纳,再次将连续的对象填充到同一个容器中。当您找到颜色较少的元素时,将它们放入已经覆盖该颜色的现有箱子中。
这两种方法都不是最佳方法,但是嘿,我们不是已经知道了吗?我们刚刚勾勒出一个非正式的证明问题是 NP 难的。
祝你好运!
关于algorithm - 最小化颜色 : a variation of the knapsack algorithm?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10244833/
我正在阅读 java swing,但在理解它时遇到问题。 Color 是一个类吗? Color[] col= {Color.RED,Color.BLUE}; 这在java中是什么意思? 最佳答案 Is
我正在研究用 python 编写的 pacman 程序。其中一个模块是处理吃 bean 游戏的图形表示。这当然是一些主机颜色。列表如下: GHOST_COLORS = [] ## establishe
本网站:http://pamplonaenglishteacher.com 源代码在这里:https://github.com/Yorkshireman/pamplona_english_teache
我最近将我的手机更新为 Android Marshmallow 并在其上运行了我现有的应用程序,但注意到颜色行为有所不同:将更改应用到 View (可绘制)的背景时,共享相同背景的所有 View (引
所有 X11/w3c 颜色代码在 Android XML 资源文件格式中是什么样的? I know this looks a tad ridiculous as a question, but giv
试图让 ffmpeg 创建音频波形,同时能够控制图像大小、颜色和幅度。我已经尝试过这个(以及许多变体),但它只是返回无与伦比的 "。 ffmpeg -i input -filter_complex "
我很好奇你是否有一些关于 R 中颜色酿造的技巧,对于许多独特的颜色,以某种方式使图表仍然好看。 我需要大量独特的颜色(至少 24 种,可能需要更多,~50 种)用于堆叠区域图(所以不是热图,渐变色不起
我看到的许多 WPF 示例和示例似乎都有硬编码的颜色。这些指南 - http://msdn.microsoft.com/en-us/library/aa350483.aspx建议不要硬编码颜色。在构建
我想更改文件夹的默认蓝色 如何设置? 最佳答案 :hi Directory guifg=#FF0000 ctermfg=red 关于Vim NERDTree 颜色,我们在Stack Overflow上
是否有关于如何将任意字符串哈希为 RGB 颜色值的最佳实践?或者更一般地说:3 个字节。 你问:我什么时候需要这个?这对我来说并不重要,但想象一下任何 GitHub 上的那些管图 network pa
我正在尝试将默认颜色设置为自定义窗口小部件。 这是有问题的代码。 class ReusableCard extends StatelessWidget { ReusableCard({this.
import javax.swing.*; import javax.swing.table.DefaultTableCellRenderer; import javax.swing.table.Ta
我有一个 less 文件来定义一堆颜色/颜色。每个类名都包含相关颜色的名称,例如 .colourOrange{..} 或 .colourBorderOrange{..} 或 navLeftButtOr
我有一个RelativeLayout,我需要一个黑色背景和一个位于其中间的小图像。我使用了这段代码: 其中@drawable/bottom_box_back是: 这样我就可以将图像居中了。但背
我需要设置 浅色 的 JPanel 背景,只是为了不覆盖文本(粗体黑色)。 此刻我有这个: import java.util.Random; .... private Random random =
我正在尝试制作一个自定义文本编辑器,可以更改特定键入单词的字体和颜色。如何更改使用光标突出显示的文本的字体和/或颜色? 我还没有尝试过突出显示部分。我尝试获取整个 hEdit(HWND) 区域并更改字
我想改变我整个应用程序的颜色。 在我的 AndroidManfiest.xml 中,我有正确的代码: 在 values 文件夹中,我有 app_theme.xml: @style/MyAc
是否可以使用 android 数据绑定(bind)从 xml 中引用颜色? 这很好用: android:textColor="@{inputValue == null ? 0xFFFBC02D : 0
有没有办法在 Android 应用程序中设置“空心”颜色? 我的意思是我想要一个带有某种背景的框,而文本实际上会导致背景透明。换句话说,如果整个 View 在蓝色背景上,文本将是蓝色的,如果它是红色的
我用CGContextStrokePath画在白色背景图片中的一条直线上,描边颜色为红色,alpha为1.0画线后,为什么点不是(255, 0, 0),而是(255, 96, 96)为什么不是纯红色?
我是一名优秀的程序员,十分优秀!