Pagini recente » Cod sursa (job #2262549) | Cod sursa (job #149547) | Cod sursa (job #987852) | Cod sursa (job #1857052) | Cod sursa (job #2153054)
#include <bits/stdc++.h>
#define in "nrcuv.in"
#define out "nrcuv.out"
#define oo 104659
using namespace std;
ifstream fin(in);
ofstream fout(out);
int n,k;
int a[30][30];
int dp[1005][30];
void Read()
{
char x,y;
int i;
fin >> n >> k;
for (i = 1; i <= k; i++)
{
fin >> x >> y;
a[x - 'a'][y - 'a'] = a[y - 'a'][x - 'a'] = 1;
}
}
int main()
{
int i,j,k;
Read();
/// initializare
for (i = 0; i <= 25; i++)
dp[1][i] = 1;
/// recurenta
for(i = 2; i <= n; i++)
for(j = 0; j < 26; j++)
for(k = 0; k < 26; k++)
if(a[j][k] == 0 && a[k][j] == 0)
dp[i][j] = (dp[i][j] + dp[i - 1][k]) % oo;
/// solutia
int sol = 0;
for (i = 0; i < 26; i++)
sol = (sol + dp[n][i]) % oo;
fout << sol << "\n";
fin.close();
fout.close();
return 0;
}