- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在这个问题上摸不着头脑,我可能会认为它是错误的。
基本上是背包问题,但有所修改。你有一组不同重量的元素,你要将它们放在三个背包中,每个背包可容纳 20 个。
我有代码可以随机初始化麻袋中的所有元素。这意味着我可以有超过 20、少于 20 和等于 20 的袋子。问题是所有项目都被添加因此我的总分对所有人口都是相同的,因此不可能变异。
例如,
如果我有四个人口,这意味着我会有其他带有背包的基因组对象,例如这些背包之间的分数不同,但总数将相同。
我只是想我可以运行一个代码来随机生成一个随机数来重新分配第一代的项目而不是在初始化时,但我也可能是错的。 .
我该如何计算一个独特的分数(评估适应度),这样我就可以移除最低的基因组并在剩余的基因组上进行变异?
分数 - 容量始终是相同的数字。
(x 在其他论坛发帖)
最佳答案
您可以使用不同的信息编码,以允许元素从背包中取出。
例如,我会将基因视为元素的背包编号,0
表示该元素不在任何背包中:
gene[0] = 1 (item 0 is in knapsack 1)
gene[1] = 0 (item 1 is not in any knapsack)
gene[2] = 3 (item 2 is in knapsack 3)
gene[3] = 2 (item 3 is in knapsack 2)
gene[4] = 1 (item 4 is in knapsack 1)
所以一个人代表了 3 个背包的可能解决方案。例如,您可以在种群中拥有 100 个人。
有了这种信息编码,计算变异和繁殖就很容易了。
要使基因发生变异,您只需为其分配一个新值,该值是 [0,3] 范围内的随机数。例如变异算法:
n = number of genes
mutation_rate = 0.01 // it means a mutation rate of 1%
For i from 0 to n-1
r = random real number between 0.0 and 1.0
If(r < mutation_rate)
gene[i] of new individual = (random integer number) modulo 4
Else
gene[i] of new individual = gene[i] of original individual
EndIf
EndFor
如果要实现繁殖,只需要选择第一个个体的一半基因,以及第二个个体的另一半基因即可。
n = number of genes
For i from 0 to n-1
r = random integer number
If(r modulo 2 == 0)
gene[i] of new individual = gene[i] of first individual
Else
gene[i] of new individual = gene[i] of second individual
EndIf
EndFor
您可以将两个先例算法合二为一,以便比先计算一个 child 然后再对其进行变异更有效地计算两个个体的变异后代。
我不是健身功能方面的专家,但我认为您可以从以下内容中得到启发,这是非常基本的,只需考虑到背包必须尽可能多地装满这一事实。对于这个适应度函数,适应度值越高,解越好:
n = number of genes
fitness = 0
weight_noknapsack = 0
weight_knapsack1 = 0
weight_knapsack2 = 0
weight_knapsack3 = 0
For i from 0 to n-1
Switch gene[i]
case 0: weight_noknapsack += item[i].weight
case 1: weight_knapsack1 += item[i].weight
case 2: weight_knapsack2 += item[i].weight
case 3: weight_knapsack3 += item[i].weight
EndSwitch
EndFor
If(weight_knapsack1 <= MAX_WEIGHT_KNAPSACK1)
fitness += weight_knapsack1
EndIf
If(weight_knapsack2 <= MAX_WEIGHT_KNAPSACK2)
fitness += weight_knapsack2
EndIf
If(weight_knapsack3 <= MAX_WEIGHT_KNAPSACK3)
fitness += weight_knapsack3
EndIf
它计算适应度,但我认为可能有更好的适应度函数。
关于c# - 多重内背包及适应度计算,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40296137/
我遇到了问题,似乎无法解决。 基本上,我希望我的菜单和文本随着分辨率的变化/放大/缩小而调整大小;图片工作正常,内容 div 工作正常,只是菜单似乎无法适应。 请帮我解决这个问题.. 普通 View
我在map reduce上开发了大约20个工作,包括pagerank算法。我从未发现任何具有挑战性的问题可以在线适应mapreduce框架。我想提高自己的技能。有这样的指南吗? 最佳答案 您正在寻找的
我了解到 Java 中没有 NOR,我可以使用 !A && !B 或 !(A||B)。既然 A 和 B 都是假的,为什么我不能使用 !A || B? 最佳答案 因为Java没有NOR运算符,你的表达式
我需要根据构建 CLI 工具的要求评估“GO”,该工具应该可以在不同的操作系统中运行。这是如何在诸如“Cloud Foundry CLI”之类的 CLI 工具中实现的?GO 如何处理这种对操作系统的适
所以我试图让我的下拉菜单正常工作。下拉列表位于我的标题中的列表项下,该列表项会根据用户的用户名而变化。这使得大小不同,但我无法让下拉菜单跟随宽度调整大小。 示例 1: http://jsfiddle.
我已经很努力了,但我还是被 matplotlib 卡住了。请忽略,mpl 文档让我有点困惑。我的问题涉及以下方面: 我用 matshow 函数画了一个对称的 n*n 矩阵 D。行得通。 我想做同样的事
我正在尝试调整 Boyer-Moore c(++) Wikipedia implementation获取字符串中模式的所有匹配项。实际上,维基百科实现返回第一个匹配项。主要代码如下: char* bo
我在底部嵌套了带有文本的 flex 元素。顶部元素具有小于文本的固定宽度: .list-header { display: flex; width: 150px; height: 80px
我想初始化 std::any带有仅 move 类型变量。我找到了 Cannot move std::any . 编译错误案例 在使用链接答案中的 shared_ptr 解决方法之前,我测试了以下代码:
现在我正在使用 webview 处理 ListView 。在这个 listview webview 中用于显示图像。它来自 url。现在我面临一个问题,我无法从 url 获得唯一尺寸的图像,一些图像很
我的文件夹结构是这样的: src --main.cpp tests --src ----main_test.cpp Makefile 我想制作一个像make main_test这样的目标,以便能够以.
前段时间我也在讨论类似的话题。我正在查看我的应用程序,我认为它有很多不必要的代码。我的意思是我有服务负责从两家书店的不同类别的书籍中抓取数据。现在我有 5 个类别,所以我有 5 个方法,但如果我要添加
我使用多个 div 子元素创建父元素,然后根据 data-value 属性在 JavaScript 中计算这些子元素的宽度。 如果我对所有 child 的计算宽度求和,我最终将得到 100%。但出于某
我像这样使用减速板 gem : require 'airbrake' Airbrake.configure do |config| config.api_key = 'XXXXX' confi
我们在企业环境中有一个 svn 存储库结构,如下所示: root libs shared_lib1 shared_lib2 private_lib public_cod
我制作了一个应用程序,其中有许多从 UIView 子类化的 View 。这些 View 的大小和方向是随机的,并且可以保存应用程序屏幕的状态。当用户在打开屏幕的同一设备上保存屏幕时,屏幕状态为“正常”
我需要调整 lucene 的 StandardTokenizer 以适应有关 twitter 数据的一些特殊目的。目前,我使用 StandardTokenizer 来标记一些我想要处理的推文。它工作得
在Windows Store应用中,如果内容是固定的,我们可以把它封装成一个ViewBox,让内容适应不同的分辨率。但是,如果内容不固定,在我的应用程序中,有一个 GridView 哪些项目是动态的,
一切都在标题中。 在我的应用程序中,根据用户所做的选择,我用一个列表填充一个组合框,该列表有时很小(1 个元素)有时很大(150 个元素)。 我想要的不是在启动时将固定高度设置为给定值,而是将 max
我的 2 div 动画感谢我下面的 jquery 脚本。当屏幕小于 700px 时,div 变成更小的正方形(35px 而不是 50px)。我希望 .animate({width:100px}); 仅
我是一名优秀的程序员,十分优秀!