0分求调
查看原帖
0分求调
1403459
parheps楼主2024/10/23 20:21
#include<bits/stdc++.h>
#define ull unsigned long long
using namespace std;
int w[105],f[105][105]; 
int n;
void dfs(int l,int r){
	if(l==r) cout<<r<<" ";
    else if(l<r){
    	for(int i=l;i<=r;i++){
    		if(f[l][r]==w[i]+f[l][i-1]*f[i+1][r]){
    			cout<<i<" ";
    			dfs(l,i-1);
    			dfs(i+1,r);
    			break;
			}
		}
	}
}
int main(){
cin>>n;
for(int i=1;i<=n;i++)cin>>w[i];
for(int i=0;i<=n;i++){
	f[i+1][i]=1;
}
for(int len=1;len<=n;len++){
	for(int i=1;len+i-1<=n;i++){
	    int j=len+i-1;
		if(len==1)f[i][j]=w[i];
		else{
		   for(int k=i;k<=j;k++){
		   	   f[i][j]=max(f[i][j],w[i]+f[1][k-1]*f[k+1][j]);
		   }	
		}
	}
} 
cout<<f[1][n];
dfs(1,n);
return 0;
}

2024/10/23 20:21
加载中...