我需要找到构成一定金额的最佳硬币组合。基本上,我想用最少量的硬币到达那里。
例如:
如果货币系统有硬币:{13,8,1},贪婪的解决方案会将24改为{13,8,1,1,1},但真正的最优解是{8,8 ,8}。
我希望用Javascript写这个,但伪代码很好,因为我相信这会有助于更多人。
答案 0 :(得分:6)
一般来说,问题实际上是NP完全的(见Change-making problem)。但是,对于许多货币系统(包括{1,5,10,25}的美国系统),贪婪算法也恰好是最优的。
答案 1 :(得分:1)
这个问题尖叫动态编程。
基本的伪代码应该是这样的:
请注意,此算法适用于您所指的一般情况。对于任何其他硬币系统,每个硬币是其后的硬币(世界上大多数硬币系统)的除数 - 贪婪的解决方案是最简单的,并且是最佳的。