Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >从给定的数字中找到一个序列,该序列的总和是给定值?

从给定的数字中找到一个序列,该序列的总和是给定值?
EN

Stack Overflow用户
提问于 2013-10-29 18:08:58
回答 2查看 1.1K关注 0票数 3

给定一组整数(正数或负数),如何找到这些数字的和为给定值的序列?

示例:给定一个数字列表[4,-16, 9, 33],我需要求和17。我可以选择sequence [4, 4, 9](数字可以重用)或[-16, 33]。我正在尝试找到一种有效的方法来减少序列的长度。

它类似于Subset Sum Problem (http://en.wikipedia.org/wiki/Subset_sum),但在我的例子中,数字可以重用。

这也有点像分区问题(Find all possible subsets that sum up to a given number),但在我的例子中有负值。

我目前的贪婪算法如下。在每个循环中,我将尝试找到一个使当前和与目标和之间的差值最小化的数字。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
integers = [-2298478782, 1527301251, 4, 4078748803, 3388759435,
        1583071281, 2214591602, 1528349827, -12, 59460983,
        -939524100, -1, 2315255807]
target_sum = 1997393191

difference = target_sum
chain = list()
while difference != 0:
    min_abs_difference = abs(difference)
    next_int = 0
    found = False
    for i in integers:
        new_abs_diff = abs(i+difference)
        if new_abs_diff < min_abs_difference:
            found = True
            next_int = i
            min_abs_difference = new_abs_diff
    if not found:
        print(difference)
        print(chain)
        print("Cannot find an integer that makes difference smaller")
        break
    difference += next_int
    chain.append(next_int)
print(chain)
EN

回答 2

Stack Overflow用户

发布于 2013-10-29 18:18:11

很可能没有一个快速的算法可以给出一个最优的解决方案。子集求和问题是NP完全的,这个问题比你的问题容易(因为你允许重复使用数字)。

考虑到这个问题是NP完全的,我认为您应该专注于改进当前的算法,或者用更快的语言(如C )重写它,然后您就可以从Python中调用C代码了。

票数 1
EN

Stack Overflow用户

发布于 2013-10-29 18:25:24

因为它显然至少是NP完全问题,所以你可以把它描述成一个混合整数线性规划问题。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Minimize summation( Xi ) // Xi = number of times the array element Ai is used.
Subject To
     summation( Ai*Xi ) = S.
     Xi >= 0 { Xi are all integers }

您可以使用任何求解器来求解它。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19665962

复制
相关文章

相似问题

如何从一个列表中找到数字,结果是基于给定数字的序列?

23

如何在excel中找到给定数字的最大序列?

12

从给定的字符串中找到给定长度的子序列?

24

给定数字的总和

226

序列给出了已经给定的数字

14
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文