Cod sursa(job #1094458)

Utilizator VictorPescaruVictor Pescaru VictorPescaru Data 29 ianuarie 2014 14:14:52
Problema Parantezare optima de matrici Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 1.18 kb
#include <fstream>
#define DMAX 504
#define INFINIT 1000000000000000
using namespace std;
ifstream fin ("podm.in");
ofstream fout ("podm.out");

long long int n;
long long int d[DMAX];
long long int nrmin[DMAX][DMAX];

void afisare( );
void citire ( );
void pd ( );

int main()
{
    citire();
    pd();
    afisare();
    return 0;
}

void citire ( )
{
    int i;
    fin>>n; for(i=0; i<=n; i++) fin>>d[i];
}

void pd()
{
    int i, x, j, k, minim, kmin;
    //initializam
    // doua matrici
    for(i=1; i<=n; i++)
        {
            nrmin[i][i+1]=d[i-1]*d[i]*d[i+1];
        }
    for(x=3; x<=n; x++)
        for(i=1; i<=n-x+1; i++)
            {
                //x matrici incepand de la pozitia i  Ai...Ai+x-1
                j=i+x-1;
                minim=INFINIT;
                for(k=i; k<j; k++)
                    if(minim>nrmin[i][k]+nrmin[k+1][j]+d[i-1]*d[k]*d[j])
                    {minim=nrmin[i][k]+nrmin[k+1][j]+d[i-1]*d[k]*d[j];
                    kmin=k;
                    }
                    nrmin[i][j]=minim;
                    nrmin[j][i]=kmin;
            }
}

void afisare ()
{
    fout<<nrmin[1][n]<<'\n';
}