标签:
4
2 3 5 10
710
题意:这个题目与1055不同 并不是摆成一排而是成串的首尾相接的 ,分析题目就是
每次消除一颗珠子k 代价为a[k-1]*a[k]*a[k+1] 问直到剩下一个珠子 代价和的最大值
题解:这个题目很神 具体看代码中的注释
另外 tyvj有毒 多组输入会wa8
1 /****************************** 2 code by drizzle 3 blog: www.cnblogs.com/hsd-/ 4 ^ ^ ^ ^ 5 O O 6 ******************************/ 7 //#include<bits/stdc++.h> 8 #include<iostream> 9 #include<cstring> 10 #include<cstdio> 11 #include<map> 12 #include<algorithm> 13 #include<cmath> 14 #define ll long long 15 #define PI acos(-1.0) 16 #define mod 1000000007 17 using namespace std; 18 int n; 19 int a[205]; 20 int dp[205][205]; 21 int main() 22 { 23 scanf("%d",&n); 24 for(int i=1; i<=n; i++)//针对环的处理 25 { 26 scanf("%d",&a[i]); 27 a[i+n]=a[i]; 28 } 29 memset(dp,0,sizeof(dp)); 30 int ans=0; 31 for(int gg=2*n-1; gg>=n; gg--)//gg为区间遍历的上界 32 { //分段分段的相当于考虑项链拆分的所有情况 33 for(int i=gg; i>=gg-n+1; i--) //下面的三层循环类似 沙子合并 34 { 35 for(int j=i+1; j<=gg; j++) 36 { 37 for(int k=i; k<j; k++)//k为分解点 注意k的左边界 38 dp[i][j]=max(dp[i][j],dp[i][k]+dp[k+1][j]+a[i]*a[k+1]*a[j+1]);//*注意 39 }//考虑第一个珠子可能会和j+1(就是它本身)先结合 把环拆开可以想象成首尾相同 40 } 41 ans=max(ans,dp[gg-n+1][gg]); 42 } 43 printf("%d\n",ans); 44 return 0; 45 }
标签:
原文地址:http://www.cnblogs.com/hsd-/p/5723801.html