算法设计与分析P3-4.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
算法设计与分析P3-4

问题描述设有n种不同面值的硬币,各硬币的面值存于数组T[1:n]中。现要用这些面值的硬币来找钱,可以实用的各种面值的硬币个数不限。(1)当只用硬币面值T[1],T[2],…,T[i]时,可找出钱数j的最少硬币个数记为C(i,j)。若只用这些硬币面值,找不出钱数j时,记C(i,j)=∞。给出C(i,j)的递归表达式及其初始条件。其中,1≤i≤n,1≤j≤L.(2)设计一个动态规划算法,对于1≤j≤L,计算出所有的C(n,j).算法只允许使用一个长度为L的数组。用L和n作为变量表示算法的时间复杂性。(3)在C(n,j),1=j=L,已计算出的情况下,设计一个贪心算法,对任意钱数m=L,给出用最少硬币找钱m的方法。当C(n,m)≠∞时,算法的计算时间为O(n+C(n,m))。分析这个问题用动态规划来解,归结到动态规划上面就变成了无限背包问题。区别在于,现在我们需要求一个最少的硬币数而不是最大值。但是选择的情况也是相同的,即每次选择都可以选择任何一种硬币。首先,找零钱问题具有最优子结构性质:兑换零钱问题的最优子结构表述:对于任意需要找的钱数j,一个利用T[n]中的n个不同面值钱币进行兑换零钱的最佳方案为P(T(1),j),P(T(2),j),...,P(T(n),j),即此时的最少钱币个数C(n,j)则P(T(2),j),...,P(T(n),j)一定是利用T[n]中n个不同的面值钱币对钱数j=j-P(T(1),j)* T(1)进行兑换零钱的最佳方案。其次,找零钱问题具有重叠于问题性质:a)当n=1时,即只能用一种钱币兑换零钱,钱币的面值为T[0],有(2)?根据分析建立正确的递归关系:复杂度:算法的时间复杂度主要取决于程序的两个循环,所以算法的时间复杂度为:O(n2);算法执行过程中引入了一个二维数组,随着输入规模的增大,所需要的空间复杂度为:O(n2)算法: #includeiostream #includecstring using namespace std; #define MAX 20002 #define INF 9999999 #define min(a,b) (a)(b)?(b):(a) int T[11],Coins[11],n;//硬币面值数组T[],可以使用的各种面值的硬币个数数组 Coins[],n种不同面值的硬币int c[MAX];//数组c[]存放要找的最少硬币个数int m; //要找的钱数mvoidinit(){ inti;cout输入硬币的面值种数:;cinn;cout\n输入硬币面值及其此面值硬币的个数:endl; for(i=0;in;++i) { cinT[i]Coins[i]; }cout\n输入要找的钱数:;cinm; } int main(intargc, char *argv[]) { init(); for(inti=0;i=m;++i) c[i]=INF; c[0]=0; for(inti=0;in;++i) { for(int j=1;j=Coins[i];++j) { for(int k=m;k=T[i];--k) c[k]=min(c[k],c[k-T[i]]+1); } } if(c[m]!=INF)cout\n最少硬币个数为:c[m]endl; elsecout-1endl; return 0; }运行结果:时间复杂度:?从上面算法可知,最优值c[j]的计算过程中,最外层为循环for(j=1;j=L;j++)嵌套着while(k1flag==0)循环,而while(k1flag==0)循环中又嵌套着三个并列的for循环。因此本算法最坏情况下的复杂度是O(L*2n);最好的情况当然是里面for循环的条件不满足而不执行,此时的复杂度为O(L*n)。其中:L表示需要兑换的零钱数,对于L来说,该值一般不是很大,对于钱币来说,L会小于100元,即10?000分;n表示钱币的种类,n值一般不会很大.如钱币总的有13种(从1分,2分,?,100元)。经过以上分析,如是最坏情况时的复杂度应为O(L*2n),则该值对于内存和运行速度较小的自动售货机等的应用前景则不会很好。但本算法中的递归结构在LT[n]时,有可见对于钱币j=L时,求c(n,j)时,并不要求对从1≤i≤j,的所有情况都要求c(n,i)+1,而是只求。其中:1≤k≤n。钱币一般只有13种左右,因此其效率大为上升。最坏的情况下需要执行而M小于100元即10000分,远大于n。本算法的动态规划算法的时间复杂性

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档