Pagini recente » Cod sursa (job #1586811) | Cod sursa (job #126227) | Cod sursa (job #891139) | Cod sursa (job #1138410) | Cod sursa (job #1429673)
#include <fstream>
using namespace std;
ifstream fin ("nrcuv.in");
ofstream fout ("nrcuv.out");
const int p = 104659;
int n, m, r[26][26], dp[1001][26], sum;
int main() {
fin >> n >> m;
for(char a, b; m; m--) {
fin >> a >> b;
r[a - 'a'][b - 'a'] = 1;
r[b - 'a'][a - 'a'] = 1;
}
for (int i = 0; i <= 25; i++)
dp[1][i] = 1;
for (int i = 2; i <= n; i++)
for (int j = 0; j <= 25; j++)
for (int k = 0; k <= 25; k++)
if (!r[j][k])
dp[i][j] = (dp[i][j] + dp[i - 1][k]) % p;
for (int i = 0; i <= 25; i++)
sum = (sum + dp[n][i]) % p;
fout << sum;
return 0;
}