Cod sursa(job #2346059)

Utilizator SqueekDanielTodasca Daniel SqueekDaniel Data 17 februarie 2019 00:00:25
Problema Culori Scor 24
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.85 kb
#include <bits/stdc++.h>

#define MAXN 260
#define MOD 9901

int N, V[MAXN];
int DP[MAXN][MAXN];

std::ifstream In ("culori.in");
std::ofstream Out("culori.out");

void Citire() {
    In >> N;
    N = 2*N-1;
    for (int i=1; i<=N; ++i)
        In >> V[i];
}

void Rezolvare() {
    for (int i=1; i<=N; ++i)
        DP[i][i] = 1;

    for (int len=2, i, j; len<=N; ++len) {
        for (i=1; i+len-1<=N; ++i) {
            if (V[i] == V[i+len-1]) {
                DP[i][i+len-1] = DP[i+1][i+len-2];
                for (j=i+2; j<=i+len-3; ++j)
                    if (V[j] == V[i])
                        DP[i][i+len-1] += DP[i+1][j-1] * DP[j][i+len-1],
                        DP[i][i+len-1] %= MOD;
            }
        }
    }   Out << DP[1][N] << '\n';
}

int main()
{
    Citire();
    Rezolvare();

    return 0;
}