Cod sursa(job #1651522)

Utilizator pas.andreiPopovici Andrei-Sorin pas.andrei Data 13 martie 2016 14:51:57
Problema Culori Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.1 kb
#include <cstdio>
#include <iostream>
#include <vector>
#include <queue>
#include <utility>
#include <algorithm>
#include <functional>
#include <string>
#include <cstring>
#include <cmath>
#include <map>
#include <set>
#include <bitset>
#include <stack>
#include <iomanip>
#include <fstream>
#define MOD 9901
#define NMAX 600
#define INF 0x3f3f3f3f
#define pb push_back

using namespace std;

FILE *fin = freopen("culori.in", "r", stdin);
FILE *fout = freopen("culori.out", "w", stdout);

typedef pair<int, int> pii;

int v[NMAX], dp[NMAX][NMAX];

inline int memo(int st, int dr) {
	int &ret = dp[st][dr];

	if (ret != -1)
		return ret;
	if (v[st] != v[dr] || st > dr)
		return ret = 0;
	if ((dr - st) % 2 == 1)
		return ret = 0;

	int i;
	ret = 0;
	for (i = st + 1; i < dr; ++i)
		ret = (ret + memo(st + 1, i)*memo(i + 1, dr)) % MOD;

	return ret;
}

int main() {
	int i, n, m, j;
	char ch;

	cin >> n;
	for (i = 1; i <= 2 * n - 1; ++i)
		cin >> v[i];

	memset(dp, -1, sizeof(dp));
	for (i = 1; i < 2 * n; ++i) dp[i][i] = 1;
	cout << memo(1, 2 * n - 1);

	return 0;
}