- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
最近下载
- 劳动教育论文:依托学校种植园培养小学生劳技素养的实践研究.docx VIP
- 《斯特林制冷机》课件.ppt VIP
- 2024北京清华附中初二(上)期中物理(教师版).docx
- 2025领导干部任前廉政法规知识竞赛题库及参考答案.docx VIP
- 三个女性文本和一种帝国主义批评.pdf
- 2023学年新教材高中英语Unit3Festivalsandcustoms写作指导介绍传统节日课件牛津译林版必修第二册.pptx VIP
- 技术要素市场化配置水平测度及区域差异分析.pdf
- 统计预测与决策教材.pdf VIP
- 17J008 挡土墙(重力式、衡重式、悬臂式)(最新).pdf VIP
- Prayer X钢琴谱五线谱 完整版原版.pdf
文档评论(0)