数集的子集和
2013-3-26 19:34:13
收藏:0
阅读:144
评论:2
假设我有一个数 n 和一个数字表。我想从表格中选择最多四个数字,这四个数字的和将最接近 n。给定表的长度 L,要穷举的组合数为(6L + 11L^2 + 6*L^3 + L^4)/24。
例如,假设变量为
n = 100
数字集合为
t = {86, 23, 19, 8, 42, 12, 49}
给定此列表,最接近 n 的四个数字的组合为 49 + 23 + 19 + 8 = 99。
使用最少的计算量,最佳方法是什么?
点赞
用户1847592
假设所有数字都是正整数,可以像 Yexo 提出的那样做:
local n = 100
local t = {86, 23, 19, 8, 42, 12, 49}
local max_terms = 4
-- best[subset_size][terms][k] = {abs_diff, expr}
local best = {[0] = {}}
for k = 1, n do best[0][k] = {k, ''} end
for terms = 0, max_terms do best[terms] = best[0] end
for subset_size = 1, #t do
local new_best = {}
for terms = subset_size == #t and max_terms or 0, max_terms do
new_best[terms] = {}
for k = subset_size == #t and n or 1, n do
local b0 = best[terms][k]
local diff = k - t[subset_size]
local b1 = terms > 0 and (
diff > 0 and {
best[terms-1][diff][1],
best[terms-1][diff][2]..'+'..t[subset_size]
} or {math.abs(diff), t[subset_size]}
) or b0
new_best[terms][k] = b1[1] < b0[1] and b1 or b0
end
end
best = new_best
end
local expr = best[max_terms][n][2]:match'^%+?(.*)'
print((loadstring or load)('return '..expr)()..' = '..expr)
-- 输出
99 = 23+19+8+49
2013-03-26 20:46:38
评论区的留言会收到邮件通知哦~
推荐文章
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法
这似乎是“子集和问题”的一个变体(参见:http://en.wikipedia.org/wiki/Subset_sum_problem),已知这是 NP 完全问题,所以不幸的是,最坏情况下运行速度可能不会比指数级算法更快。
如果要检查的项不多(约为 10 个左右),则可以尝试深度优先搜索,并尽早修剪分支。
如果要检查的项很多,最好尝试找到一个近似的解,而不是搜索最优解。