能量项链分析和总结.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文档。上传文档
查看更多

能量项链

【描述】

在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),为一个最优聚合顺序所释放的总能量。

【样例输入】

4

23510

【样例输出】

710

【解题日志】

写这道题好不容易啊!

这道题是典型的区间动归的题目,按照石子归并题目的思想,可以将数组扩展成二倍的形式,

如样例可以扩展为

左边的数:

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 30210 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 60210710 0

0 0 0 0 0 30210250

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减一才行。

【参考程序】

var

f:array[1..200,1..200]oflongint;a:array[1..200,1..2]oflongint;n,i,j,k,max,stt:longint;

beginreadln(n);

fori:=1tondoread(a[i,1]);

fori:=1ton-1doa[i,2]:=a[i+1,1];

a[n,2]:=a[1,1];

fori:=n+1to2*ndobegina[i,1]:=a[i-n,1];

a[i,2]:=a[i-n,2];

end;

forj:=1ton-1dofori:=1to2*n-jdo

文档评论(0)

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

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

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

1亿VIP精品文档

相关文档