- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试确定解决我的问题的最佳方法,如下所示:
我有一组对象(大约 3k-5k),我想将其唯一分配给大约 10 个组(每个对象 1 个组)。每个对象都有一组等级,对应于它在每个组中的适合程度。每个组都有它可以管理的对象的容量(约束)。我的目标是最大限度地提高我的作业获得的总成绩。
例如,假设我有 3 个对象(o1、o2、o3)和 2 个带帽的组(g1、g2)。每个 1 个对象。现在假设成绩是:
o1: g1=11, g2=8
o2: g1=10, g2=5
o3: g1=5, g2=6
在那种情况下,为了获得最佳结果,g1 应该接收 o2,g2 应该接收 o1,总共产生 10+8=18 分。
请注意,对象的数量可能会超过配额的总和(例如,将 o3 作为“剩余”)或未达到配额。
我应该如何解决这个问题(旅行推销员,一种加重的背包等)?在普通计算机上暴力破解需要多长时间?是否有任何标准工具(例如 Matlab 中的 linprog 函数)支持此类问题?
最佳答案
可以用最小成本流算法解决。该图可能如下所示:
应该是双向的。左侧部分表示对象(每个对象一个顶点)。右侧部分代表组(每个组一个顶点)。从左侧部分的每个顶点到右侧部分的每个顶点都有一条边,capacity
= 1 且 cost
= 这对的等级。从源顶点到左侧部分的每个顶点也有一条边,capacity
= 1 且 cost
= 0,并且从右侧部分的每个顶点都有一条边到接收器顶点(接收器和源是两个额外的顶点),capacity
= constraints for this group and cost
= 0.
答案是——从源到汇的最便宜的流成本
。
可以用 O(N^2 * M * log(N + M))
时间复杂度(使用带势的 Dijkstra 算法)(N
是对象的数量,M
是组的数量)。
关于algorithm - 离散优化算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24342695/
如何在 Flutter 中使 slider 离散看起来像上图? slider discrete 最佳答案 使用 divisions Slider 的属性(property)小部件将其分成相等的部分,然
我正在创建一个带有颜色条的散点图 plt.scatter(X, Y, c=Z) plt.colorbar() plt.show() plt.close() 其中 X 和 Y 是 float 组,Z 是
我刚刚在 android studio 中发现了 seekbar 离散小部件,我发现它非常有用,但我不知道如何删除步骤指示器,或者用更合适的可绘制对象更改它们。 有人设法做到了吗? 这是我当前搜索栏的
问题 请注意以下问题:巫师可以创建和销毁 rune 。创建一个新的 rune 需要消耗与先前创建的 rune 数量成比例的法力。摧毁 rune 会恢复创建 rune 所用的法力。下面,我提出一个可能的
我正在尝试使用 ggplot2 中的 sf 和 geom_sf 制作 map ,其中一组点数据使用连续颜色比例(-1 到 1),一组线数据使用离散比例(a、b、c、d)着色。但是,当我在同一张 map
我正在尝试在具有连续状态(dim.= 20)和离散操作(3 个可能的操作)的环境中找到最佳策略。并且有一个特定的时刻:对于最佳策略,一个操作(称为“操作 0”)的选择频率应比其他两个操作高得多(频率约
仅使用 x-y 位置移动绘制圆弧的最佳方法是什么?例如,假设我想在点 (4,4) 处绘制一个半径为 4 的圆。让我们看看我的“抽屉”从 (4,0) 开始,每个方向的分辨率为 0.1 步。我将如何创建一
我正在使用一个使用广义加法模型的随机站点级效应来拟合一个模型,该模型在 mgcv 中实现。 R 包。我一直在使用函数 gam() 执行此操作但是,为了加快速度,我需要转到 bam()框架,与gam()
这个问题在这里已经有了答案: Make a line separated by group in bar chart (3 个答案) 关闭上个月。 我正在尝试使用 ggplot2 在条形图的每个条上
这个问题在这里已经有了答案: Make a line separated by group in bar chart (3 个答案) 关闭上个月。 我正在尝试使用 ggplot2 在条形图的每个条上
是否可以同时使用 Intel HD 4000 集成显卡和独立 GPU,OpenCL(或 CUDA)作为设备,CPU 作为主机?我想要一些代码在集成显卡上运行,而其他代码同时在我的 GPU 上运行。 最
我是一名优秀的程序员,十分优秀!