Pagini recente » Cod sursa (job #2092198) | Monitorul de evaluare | Cod sursa (job #3161331) | Cod sursa (job #1219744) | Cod sursa (job #447506)
Cod sursa(job #447506)
#include<cstdio>
using namespace std;
struct matrix
{
int lin,col;
} M[512];
long long n;
long long a[512][512];
void read();
void podm();
void write();
void initializare();
int main()
{
freopen("podm.in","r",stdin);
freopen("podm.out","w",stdout);
read();
initializare();
podm();
write();
return 0;
}
void read()
{
long long i,x,y;
scanf("%ld",&n);
scanf("%ld",&x);
for (i=1;i<=n;++i)
{
scanf("%ld",&y);
M[i].lin=x;
M[i].col=y;
x=y;
}
}
void initializare()
{
long long i;
for (i=1;i<n;++i)
a[i][i+1]=M[i].lin*M[i].col*M[i+1].col;
}
void podm()
{
long long i,j,k,d,min,s;
for (d=3;d<=n;++d)
for (i=1,j=d;j<=n;++i,++j)
{
min=-1;
for (k=i;k<j;++k)
{
s=a[i][k]+a[k+1][j]+M[i].lin*M[k+1].lin*M[j].col;
if (min==-1) min=s;
if (s<min) min=s;
}
a[i][j]=min;
}
}
void write()
{
printf("%ld\n",a[1][n]);
}