Cod sursa(job #1743444)

Utilizator atatomirTatomir Alex atatomir Data 18 august 2016 10:30:16
Problema Culori Scor 48
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.98 kb
#include <iostream>
#include <cstdio>
#include <cstring>
#include <vector>
#include <algorithm>
#include <cmath>

using namespace std;

#define mp make_pair
#define pb push_back
#define ll long long

#define maxN (2 * 277)
#define mod 9901

int n, i, j;
int v[maxN];
int dp[maxN][maxN];

int solve(int l, int r) {
    int i;
    ll aux = 0;

    if (dp[l][r] == -1) {
        if (l == r) return dp[l][r] = 1;
        if (l > r) return dp[l][r] = 0;
        dp[l][r] = 0;

        if (v[l] != v[r]) return 0;

        for (i = l + 1; i <= r; i++)
            if (v[i] == v[l])
                aux += 1LL * solve(l + 1, i - 1) * solve(i, r);

        dp[l][r] = aux % mod;
    }

    return dp[l][r];
}

int main()
{
    freopen("culori.in","r",stdin);
    freopen("culori.out","w",stdout);

    scanf("%d", &n); n = 2 * n - 1;
    for (i = 1; i <= n; i++) {
        scanf("%d", &v[i]);
        for (j = 1; j <= n; j++)
            dp[i][j] = -1;
    }

    printf("%d", solve(1, n));


    return 0;
}