微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

“篮子”的最佳组合以最接近目标篮子?

如何解决“篮子”的最佳组合以最接近目标篮子?

假设我有一些长度为 n 的数组,其中 arr[k] 表示我想要多少对象 k。我也有一些任意数量的数组,我可以对任意组合的整数倍求和 - 我的目标是最小化每个元素的绝对差异之和。

举个愚蠢的例子,如果我的目标是 [2,1] 并且我的选项是 A = [2,3] 和 B = [0,1],那么我可以选择 A - 2B 并且成本为 0

我想知道是否有一种有效的算法来近似这样的东西?它有一种奇怪的背包味道,对大 n 来说可能是难对付的吗?似乎不太适合 DP 方法

解决方法

这是(NP-hard)closest vector problem。 Fincke 和 Pohst ("Improved methods for calculating vectors of short length in a lattice,including a complexity analysis") 提供了一种算法,但我没有亲自使用过。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。