采用动态规划方法解决乘积最大问题.docxVIP

采用动态规划方法解决乘积最大问题.docx

  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文档。上传文档
查看更多
采用动态规划方法解决乘积最大问题 蓝桥网站题目编号:ALGO-17 乘积最大 动态规划 VIP 试题 2013-11-07 问题描述: 设有一个长度为N 的数字串,要求选手使用K 个乘号将它分成 K+1 个部分,找出一种分法,使得这K+1 个部分的乘积最大。 同时,为了帮助选手能够理解题意,主持人还举了如下一个例子: 有一个数字串:312 ,当N=3 ,K=1 时会有两种分法: ⑴3*12=36 ⑵31*2=62 这时,符合题目要求的结果是:31*2=62 。现在,请你帮助你的好朋友XZ 设计一个程序, 求得正确的答案。 输入 程序的输入共有两行: 第一行共有 2 个自然数N ,K (2 ≤N ≤40 ,1 ≤K ≤6 ) 第二行是一个长度为N 的数字串。 输出 结果显示在屏幕上,相对于输入,应输出所求得的最大乘积(一个自然数)。样例输入 4 2 1231 样例输出 62 问题分析:本题的解法较多,这里采用动态规划方法。 假设在 n n ?n (2≤i≤n)中插入 k 个’*’。其中 n n ?n 中插入了 k-1 个’*’,即乘式中的 1 t0 1 1 t n ?n0 * n ?n 第 k+1 项为n t+1 ?n (k≤t≤i-1) ,即有形式: i ?0 ??t 插入k ?1个* t ?1 i 设 F[i][k]是长度为 i+1 的数串 n ?n n ?n 中插入k 个“*”的最大乘积(整型数组), 0 t t ?1 i 0≤k≤i。显然F[i][0]= n ?n n ?n ,i=0,1,2,…,N-1; 0 状态转移方程为: t t ?1 i F[i][k ] ? max {F[t][k ?1]* num[t ?1][i]} 0?k ?1?t 由于题目中给出的自然数位数的上限为40 ,乘号数的上限为 6 ,因此最大乘积位数的上限 接近 42 位。显然,程序设计语言中提供的整数类型都无法容纳如此之大的数据,因此我们使用数组来表示。 根据上述的状态转移方程,可写出下面的示例程序。注意程序中只是用了在长整型范围内的数据处理,如整数的分划、合成和乘法等。对超出长整型范围的数据必须通过高精度乘法的方法加以解决。 示例 C++语言程序: //动态规划法解决最大乘积问题的程序#include iostream #include cstring using namespace std; int const maxn=41; int n[maxn],len; long nn(int t,int z) // n ?n 整数的合成 t z { int i; long a=n[t]; for(i=t+1;i=z;i++) a=a*10+n[i]; return a; } int main( ) { int i,N,c,k,t; long num, F[maxn][maxn]; char s[maxn]; while(cinNc) { cins;//以字符形式输入长度为 N 的整数存入字符数组 s len=strlen(s); for(i=0;ilen;i++) n[i]=s[i]-48; //字符“0”的 ASCII 值是 48 k=0; F[0][0]=n[0]; for(i=1;ilen;i++) F[i][0]=F[i-1][0]*10+n[i]; // n n ?n 整数的分解与合成 0 1 z k=1; for(k=1;k=c;k++) { for(i=0;ilen;i++) { long a=-1; for(t=k-1;ti;t++) { num=nn(t+1,i); long b=F[t][k-1]*num; if(ab) a=b; } F[i][k]=a; } } coutF[len-1][c]endl; } return 0; }

文档评论(0)

tianya189 + 关注
官方认证
文档贡献者

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

认证主体阳新县融易互联网技术工作室
IP属地上海
统一社会信用代码/组织机构代码
92420222MA4ELHM75D

1亿VIP精品文档

相关文档