- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试使用动态规划解决问题,问题如下:
给定无限供应的硬币(便士、镍币、角钱、双角钱、四分之一)值(1、5、10、20、25),请找到最少数量的硬币找零 65 美分。使用什么硬币(以及每种硬币数量)?说明使用动态规划算法以及如何获得使用的硬币。
请注意,我不希望任何人为我说明整个表格,但我对如何为这个问题填写表格有点困惑。
我知道我的 table 看起来有点像这样:
5 10 15 20 25 30 35 40 45 50 55 60 65
1
5
10
20
25
(我省略了 1,因为我知道这不是最佳解决方案)我最初的想法是表格会像这样填写:
5 10 15 20 25 30 35 40 45 50 55 60 65
1
5 1 2 4 5 5 6 7 8 9 10 11 12 13
10 0 1
20
25
当我必须走得更远时,我会被困在这里。我不认为我完全理解动态编程如何解决这个问题。我一直在阅读我的书和在线阅读,但我仍然有点困惑。
编辑:
感谢其中一个答案,这就是我制定解决方案的方式:
5 10 15 20 25 30 35 40 45 50 55 60 65
1
5 1 1 1 1
10 1 1 1 1
20 1 2 1 2
25 1 1 1 1 2 2 2 1
最佳答案
你做错了。列代表您必须归还的总零钱,行单元格代表使用的某些硬币(便士、镍币、10 美分、20 美分、25 美分)的数量。
该算法的重点是返回最少数量的硬币。例如,如果零钱是 25,您应该退还一个季度,而不是 25 便士。您可以看到我在下表中使用四分之一作为 25 美分列。
在您的 15 零钱列中的示例中,您使用的是 4 x 5 美分,这是次优的,因为您可以使用一枚 10 美分的硬币和一枚 5 美分的硬币来返回总共 15。在 20 美分的列中您使用的是 5 x 5 美分找零,这是不正确的,而且也不是最优的,因为您本可以使用一枚 20 美分的硬币来返还 20 美分。
这是为前 5 列填充的表格。您可以填写其余部分:
5 10 15 20 25 30 35 40 45 50 55 60 65
1
5 1 1
10 1 1
20 1
25 1
--------------------------------------------------------
T 1 1 2 1 1
我在底部添加了一个 T 行来计算您用作零钱的硬币总数。你的目标是拥有最少的。此行中每一列的可能数量。
关于algorithm - 动态规划 : the smallest number of coins to make change for 65 cents,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26641168/
我并不总是编写 make 文件,但当我这样做时,我喜欢尝试并写好它们。试图使界面与其他开发人员的期望一致始终是一项艰巨的任务。我正在寻找的是所有常见的 make some clean (GNU) ma
例如,我在运行 makefile 时收到这样的错误: make[3]: *** [/home/ziga/Downloads/openwrt/rakun_openwrt/staging_dir/ho
我必须创建一个 Makefile,它从不同文件夹中的 .c 文件创建单个可执行文件。 .c 文件包含来自任何这些文件夹的头文件。根目录有3个子目录x/y、x/z、a,所有这些子目录都有一些.c和.h文
您好,我有一个简单的 MakeFile,其中包含: clean: rm -f ex1 但是当我运行命令make clean 时,出现以下错误: make: *** No rule to mak
我已经为一些软件安装了它,但现在我根本不使用那个软件,所以我需要移除MinGW才能使用Cygwin进行Android开发。。我使用的是64位Windows 7
以下是针对我遇到的问题的简化生成文件: all: /tmp/makey/../filey @echo All done /tmp/filey: @echo Filey 当我运行 mak
获取错误: make: *** No rule to make target all. Stop." 在安装nagios主机期间运行此命令make all 最佳答案 可能的常见错误: 确保将文件命名为
当使用 -jN 运行 gnu-make 规则时,make 会创建 jobserver用于管理跨子制造商的工作数量。此外,您可以通过在 make 配方前添加 + 前缀来“将作业服务器环境传递”到 mak
使用 GNU Make 4.1 概括 我调用一个子品牌 b.mk来自生成文件 a.mk .b.mk被调用以确保构建子系统。 有时我想强制一个目标为 a.mk重制: make -f a.mk --al
这个问题与问题 2543127 的精神相似。 . 我有一个带有头文件列表的 gnu makefile。每个头文件可能位于不同的目录中,例如, HEADERS = $(wildcard *.h) $(w
假设我有以下 GNU make 目标: create_dir: @mkdir objects build_asm: $(ASM_FILES) @echo
我有一个具有以下结构的 Makefile(工作示例)。 .PHONY: image flashcard put-files put-files: @echo "=== put-files" i
我想要一个这样的makefile: cudaLib : # Create shared library with nvcc ocelotLib : # Create shared li
有没有比更好的方法来获取 GNU make 变量的第一个字符 FIRST=$(shell echo $(VARIABLE) | head -c 1) (不仅笨重而且还要调用外部shell)? 最佳答案
我通常使用像 cmake 这样的高级构建系统来构建我的 C/C++ 代码。但是由于各种原因,我直接使用 GNU make。 我正在进行递归构建,其中每个目录都有一个 makefile。 我最近不得不将
我通常使用像 cmake 这样的高级构建系统来构建我的 C/C++ 代码。但是由于各种原因,我直接使用 GNU make。 我正在进行递归构建,其中每个目录都有一个 makefile。 我最近不得不将
我安装了最新的mingw,发现没有mingw32-make了。有make.exe,所以我想知道最近是否将mingw32-make重命名为make.exe。 最佳答案 我不知道您从哪里获得 MinGW,
我正在使用 CentOS,但由于一个错误,许多软件包被删除了。所以我没有 yum 和 rpm。所以我想从源代码手动制作 yum,但我也没有制作。我知道一切都会用“制作包”制作。但是 make 自己呢?
考虑这个Makefile: .PHONY: all all: main.txt main.txt: build/main.txt cp build/main.txt . %/main.txt:
假设目录输入中有 1000 个扩展名为 .xhtml 的文件,并且这些文件的某个子集(输出路径在 $(FILES) 中)需要通过 xslt 转换为目录输出中具有相同名称的文件.一个简单的 make 规
我是一名优秀的程序员,十分优秀!