能量项链解题报告及C语言实现.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文档。上传文档
查看更多
PAGE1 / NUMPAGES1 200601能量项链解题报告(C语言实现) 【描述】 在Mars星球上,每个Mars人都随身佩带着一串能量项链。在项链上有N颗能量珠。能量珠是一颗有头标记与尾标记的珠子,这些标记对应着某个正整数。并且,对于相邻的两颗珠子,前一颗珠子的尾标记一定等于后一颗珠子的头标记。因为只有这样,通过吸盘(吸盘是Mars人吸收能量的一种器官)的作用,这两颗珠子才能聚合成一颗珠子,同时释放出可以被吸盘吸收的能量。如果前一颗能量珠的头标记为m,尾标记为r,后一颗能量珠的头标记为r,尾标记为n,则聚合后释放的能量为(Mars单位),新产生的珠子的头标记为m,尾标记为n。 需要时,Mars人就用吸盘夹住相邻的两颗珠子,通过聚合得到能量,直到项链上只剩下一颗珠子为止。显然,例外的聚合顺序得到的总能量是例外的,请你设计一个聚合顺序,使一串项链释放出的总能量最大。 例如: 设N=4,4颗珠子的头标记与尾标记依次为(2,3)(3,5)(5,10)(10,2)。我们用记号⊕表示两颗珠子的聚合操作,(j⊕k)表示第j,k两颗珠子聚合后所释放的能量。则第 4、“1两颗珠子聚合后释放的能量为: (4⊕1)=10*2*3= 60。“ 这一串项链可以得到最优值的一个聚合顺序所释放的总能量为 ((4⊕1)⊕2)⊕3)=10*2*3+10*3*5+10*5*10= 710。“ 【输入格式】 输入文件energy.in的第一行是一个正整数N(4≤N≤100),表示项链上珠子的个数。 第二行是N个用空格隔开的正整数,所有的数均不超过 1000。“第i个数为第i颗珠子的头标记(1≤i≤N),当iN时,第i颗珠子的尾标记应该等于第i+1颗珠子的头标记。第N颗珠子的尾标记应该等于第1颗珠子的头标记。 至于珠子的顺序,你可以这样确定: 将项链放到桌面上,不要出现交叉,随意指定第一颗珠子,然后按顺时针方向确定其他珠子的顺序。 【输出格式】 输出文件energy.out只有一行,是一个正整数E(E≤ 2.“1*109),为一个最优聚合顺序所释放的总能量。 【样例输入】 42 3 5 10 【样例输出】 710 【解题xx】 这道题是典型的区间动归的题目,按照石子归并题目的思想,可以将数组扩展成二倍的形式,如样例可以扩展为 左边的数:2 3 5 10 2 3 5 10 右边的数:3 5 10 2 3 5 10 2 存储这个数组可以用a,a[i][1]存储左边的数,a[i][2]存储右边的数,至于f,是用来存储状态的,这里就不多解释了。 然后按照区间动归的思想写出方程,有时候写出方程有些难度,感觉较难的同学可以把数组f的所有值给列出来。 像样例 0 30 210 250 0 0 0 0 0 0 150 210 300 0 0 0 0 0 0 100 210 460 0 0 0 0 0 0 60 210 710 0 0 0 0 0 0 30 210 250 0 0 0 0 0 0 150 210 0 0 0 0 0 0 0 100 0 0 0 0 0 0 0 0 可发现需要先求出两两珠子合并后的释放的能量,这样就有需要最外层循环j,j+1代表有几个珠子合并,然后再枚举起始点,即i,i是从1到2*n-j,因为a数组扩展成了原来的两倍,并且不能越界,最后再枚举中间的断开点k,让i到k合并后的珠子,与k+1到i+j合并后的珠子进行合并,其释放的能量数为第i颗珠子左边的数,乘以第k颗珠子右边的数(也可以是第k+1颗珠子左边的数,由于都一样,这里任取其一),再乘以第i+j颗珠子右边的数,这就是其释放的能量值,再加上原有的能量,就是这个状态的值。 状态转移方程: f[i][i+j]=max{f[I][k]+f[k+1][i+j]+a[I][1]*a[k][2]*a[i+j][2]};输出时从1到n寻找长度为n的最大的能量数即可。 这里注意由于j+1代表的有几个珠子合并,输出时应将j减一才行。 【参考程序】 #include stdio.h unsigned f[100][101]; int a[100*2+1][3]; int n; int main(void){int i=0, j, k; FILE *fpr; if((fpr=f

文档评论(0)

153****2710 + 关注
实名认证
文档贡献者

非专业程序员,熟练python爬虫,制作教育游戏等。

1亿VIP精品文档

相关文档