求调
查看原帖
求调
1491309
mozhengyang801楼主2025/1/17 14:29
#include<iostream>
#include<algorithm>
using namespace std;
int n,a[110],dp[110][230],sum;
int main(){
	cin>>n;
	for(int i=1;i<=n;i++){
		int q;cin>>q;
		a[i]=a[n+i]=q;
	}
	for(int len=3;len<=n+1;len++){//长度 
		for(int m=1;m+len-1<=2*n;m++){//左端 
			int r=m+len-1;//右端 
			for(int i=m;i<r;i++)//断点 
				dp[m][r]=max(dp[m][i]+dp[i][r]+a[m]*a[i]*a[r],dp[m][r]);
		}
	}
	for(int i=1;i<=n;i++)
		sum=max(sum,dp[i][i+n]);
	cout<<sum;
	/*for(int i=0;i<=2*n;i++){
		for(int j=0;j<=2*n;j++)
			cout<<dp[i][j]<<"\t";
		cout<<"\n";
	}*/
	return 0;
}
2025/1/17 14:29
加载中...