#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;
}