- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试了解 project euler #31 的解决方案我在论坛上找到了。
问题是我们得到了具有以下值的硬币:
coins=[1,2,5,10,20,50,100,200]
我们的任务是生成达到 200 的所有可能方法。例如,10*10+100=200 就是一种可能的方法。
在浏览论坛时,我找到了这个解决方案:
p_list = [1, 2, 5, 10, 20, 50, 100, 200]
case_num = [1] + [0] * 200
for i in p_list:
for j in range(1, 201):
if i <= j:
case_num[j] += case_num[j-i]
print case_num[200]
第一行只是硬币值(value)的列表。第二行是创建一个 1 后跟 200 个 0 的数组。但是接下来的四行让我感到困惑。我认为它增加了数组中可能的方法数,因此 case_num[200] 将给出列表中的最后一个条目,但我不知道它是如何工作的。
最佳答案
正如您所说,这是一个非常好的解决方案。该代码通过每次迭代 1-200 与每种硬币面额建立在自身之上。
case_num 数组最初由 [1, 0, 0, 0, 0, 0...0, 0, 0] 组成
这些数字(除了最初的 1)的意思是您可以通过多少种方式来达到给定的总数(由数字的索引)使用到目前为止你已经迭代过的 p_list 中的硬币。
p_list 中的第一个硬币是 1。因此,如果 1 可以放入索引中,那么您可以将前一个索引中的值添加到当前索引中。这是可行的,因为如果有 5 种已知的方法可以达到 25,而你刚找到大小为 1 的硬币,那么也有 5 种方法可以达到 26。[前 5 种达到 25 的方法中的每一种] + 一个 1 硬币.
因此,在用 1 进行迭代后,您将得到 [1, 1, 1, 1, 1...1, 1]
现在您的硬币数量增加了。这次你使用的是 2 的硬币。让我们再看一遍这个过程。如果 2 小于索引,则将到达前一个索引的方法数添加到当前索引。
例如,2 不适合索引 1,但适合索引 2。因此您刚刚创建了一种从 0 到 2 的新方法,因此您采用了所有可以达到 0 的方法并将它们添加到您的当前索引。在索引 27 上,2 适合索引,因此您采用可以达到 25 的方法数并将它们添加到 27,因为现在您有(所有这些方法可以达到 25 + 一个 2 硬币)+(所有方法你必须达到 27 才能知道你有大小为 2 的硬币)。
因此,在用 2 进行迭代后,您将得到 [1, 1, 2, 2, 3, 3, 4, 4...]
如果您仍然遇到问题,尝试完成整个程序可能是值得的(可能减少总数,如 50 而不是 200)。
关于python - 欧拉计划 31 : Understanding Program Solution,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20353226/
我的构建菜单包含两个构建选项: 构建解决方案 构建MyProjectName 如果我选择Build Solution(然后是Debug,Start Debugging (F5)),运行的可执行文件不包
我有一个带有一些输入字段的表单。这些输入字段具有指定的背景渐变,如下所示: input { background: #00b7ea; background: url(data:imag
现在这个遗留代码是多个项目,每个项目都有自己的解决方案。每个项目通过它编译的 dll 引用另一个项目。要让主项目运行,您必须以正确的顺序进行 10 多个单独的构建。 我试图解释如何将所有项目移动到一个
我在 Visual Studio 2013 中处理我的项目,我错误地点击了 Rebuild Solution。我收到以下异常,我不知道如何解决它。请建议。 Server Error in '/' Ap
class solution { void table(final int n) { for (int i = 1; i <= 10; i++) { S
我非常需要了解如何使用 Visual Studio 2010 在 c# 中管理一些非常基本的体系结构问题,而且我在教科书和网站上寻找解决方案时遇到了一些困难。假设我有一个 MyWinForm.sln
我有 Java 背景,正在尝试从 C# 开始。 我想用 C# 创建一个将在其他解决方案中使用的库。在 Eclipse 中,只需创建一个 jar 并将其添加到类路径中即可。我知道VS2013中的每个项目
在我目前的工作中,我需要打开 3 个不同的解决方案,构建并运行它们。是否有任何脚本可以像我单击 Web 服务的“构建解决方案”或“启动”或“Google Chrome”一样执行工作人员? 谢谢。 最佳
有什么方法可以告诉Visual Studio 2005的解决方案资源管理器在svn-checkout后第一次打开解决方案时不要扩展所有项目? 编辑: 感谢您指出 PowerCommands。当我使用带
我的 Visual Studio 解决方案的 Subversion 存储库中有以下目录: 项目名称 标签 分支机构 后备箱 我的解决方案.sln MyProject1(目录) MyProject2(目
我刚刚使用 Update 2 更新了 Visual Studio 2015。 现在,经过几个小时的正常工作,我收到:“检测到内存不足。对此解决方案禁用了完整的解决方案分析。”出现在我的 VS2015
在 Visual Studio Code 中,单击我的测试项目中的“调试测试”代码镜头链接: 导致错误信息: MSBUILD : error MSB1011: Specify which projec
我是Docker的新手,正在尝试为ASP.NET Core应用程序创建Dockerfile。有人可以建议我需要哪些更改吗? 这是我的Dockerfile: FROM microsoft/dotnet:
我的入门类(class)的这个实验要求我们以 pig 拉丁语返回任何用户输入。当我运行它并在控制台中输入任何字符串时,我似乎不断收到的错误是: java.lang.StringIndexOutO
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 4年前关闭。 Improve this questi
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 11 个月前关闭。 Improv
我的 C++ Concert Cplex 有问题。我正在尝试重新创建最短路径问题。输出到文本文件是: Minimize obj: 2 x_12 + x_13 + 2 x_21 + x_24 + x_
有时,当我浏览我的头文件时,我想在 (doxygen) 文档中添加一些小东西。这可能是关于使用某些函数参数的快速说明,或者只是修复了一个小错字。 但后来我想:哦不,这会在下一个 make 调用时触发重
我正在使用缺少 findall 的高阶 Prolog 变体. 还有一个关于实现我们自己的问题 findall这里:Getting list of solutions in Prolog . 低效的实现
如果您的应用程序必须对大尺寸对象(> 85000 字节)进行大量分配/取消分配,则最终会导致内存碎片,并且您的应用程序将抛出内存不足异常。 这个问题有什么解决方案,还是CLR内存管理的限制? 最佳答案
我是一名优秀的程序员,十分优秀!