Pagini recente » Cod sursa (job #1107156) | Cod sursa (job #240225) | Cod sursa (job #1368801) | Cod sursa (job #2113828) | Cod sursa (job #3192152)
#include <bits/stdc++.h>
#define MAX_N 1001
#define MOD 104659
using namespace std;
ifstream fin("nrcuv.in");
ofstream fout("nrcuv.out");
int N,M;
bool notPossible[28][28];
long long DP[28][MAX_N];
int main() {
fin >> N >> M;
for (int i = 1; i <= M; i++) {
char a,b;
fin >> a >> b;
a-='a';
a++;
b-='a';
b++;
notPossible[a][b] = true;
notPossible[b][a] = true;
}
for (int i = 1; i <= 'z' - 'a' + 1; i++) {
DP[i][1] = 1;
}
for (int i = 2; i <= N; i++) {
for (int j = 1; j <= 'z' - 'a' + 1; j++) {
for (int k = 1; k <= 'z' - 'a' + 1; k++) {
if (notPossible[j][k]) {
continue;
}
DP[j][i] += DP[k][i-1];
DP[j][i] %= MOD;
}
}
}
unsigned long ans=0;
for (int i = 1; i <= 'z' - 'a' + 1; i++) {
ans += DP[i][N];
ans %= MOD;
}
fout << ans;
return 0;
}