Cod sursa(job #705195)

Utilizator iulianlazLazar Iulian iulianlaz Data 3 martie 2012 17:43:50
Problema Parantezare optima de matrici Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.82 kb
#include<iostream>
#include<fstream>
using namespace std;

#define MAXN 503
#define INF 100000

int main () {

ifstream in("podm.in");
ofstream out("podm.out");

int n, i;
int p[MAXN];
int m[MAXN][MAXN];
int s[MAXN][MAXN];
int l, k, q, j;
int inf = 30000;

in >> n;

for (i = 0; i <= n; i++)
        in >> p[i];

for (i = 0; i <= n; i++)
        cout << p[i] << " ";

for (i = 1; i <= n; i++)
    m[i][i] = 0;

for(l = 2; l <= n; l++)
    for(i = 1; i <= (n-l+1); i++) {

        j = i + l - 1;
        m[i][j] = INF;

        for (k = i; k <= j - 1; k++) {
            q = m[i][k] + m[k + 1][j] + p[i - 1]*p[k]*p[j];

            if (q < m[i][j]) {
                    m[i][j] = q;
                    s[i][j] = k;

            }
        }
    }

    out << q;




   in.close();
   out.close();


}