Cod sursa(job #2275938)

Utilizator opariucbiancaOpariuc Bianca Gabriela opariucbianca Data 3 noiembrie 2018 19:40:14
Problema Parantezare optima de matrici Scor 70
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.74 kb
#include <fstream>

using namespace std;
ifstream fin("podm.in");
ofstream fout("podm.out");

long d[505],sol[505][505],n,minim;
int main()
{
    int i;
    fin>>n;
    for(i=1;i<=n+1;i++)
    {
        fin>>d[i-1];
    }
    for(i=1;i<=n;i++)
    {
        sol[i][i]=0;
    }
    for(i=1;i<n;i++)
    {
        sol[i][i+1]=d[i-1]*d[i]*d[i+1];
    }
    for(int j=2;j<n;j++)
    {
      for(i=1;i<=n-j;i++)
      {
          minim=2000000;
          for(int k=i;k<=i+j-1;k++)
          {
              if(sol[i][k]+sol[k+1][i+j]+d[i-1]*d[k]*d[i+j]<minim)
                minim=sol[i][k]+sol[k+1][i+j]+d[i-1]*d[k]*d[i+j];
          }
          sol[i][i+j]=minim;
      }

    }
     fout<<sol[1][n]<<'\n';
    return 0;
}