- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
                您可能关注的文档
最近下载
- 留岗培训金属热处理初级工理论考试.docx VIP
- 铝方通吊顶安装施工方案及技术措施.docx VIP
- 商务英语(北京交通大学)中国大学MOOC慕课章节测验答案(课程ID:1205722812).pdf VIP
- 第37号:危险性较大分部分项工程管理规定(2018).docx VIP
- 难治性支原体肺炎诊治.pdf
- 初中语文整本书阅读教学与写作能力提升的实践课题报告教学研究课题报告.docx
- 全新版进阶视听说B1 四级听力训练4测试答案.docx VIP
- 初二下学期期中考试(数学)试题含答案.docx VIP
- 高净值人士税务观察:个人股东在并购重组中能否暂免纳税?.pdf
- 落地式外脚手架施工方案修改版.docx VIP
 原创力文档
原创力文档 
                        

文档评论(0)