Pagini recente » Cod sursa (job #966736) | Cod sursa (job #2007575) | Cod sursa (job #233887) | Cod sursa (job #3122856) | Cod sursa (job #1850179)
#include <iostream>
#include <fstream>
#define MOD 104659
using namespace std;
ifstream in("nrcuv.in");
ofstream out("nrcuv.out");
int n, m;
int dinamic[1001][27];
bool adj[26][26];
int main()
{
in>>n>>m;
for(int i=0;i<m;i++){
char a, b;
in>>a>>b;
a-='a';
b-='a';
adj[a][b] = adj[b][a] = 1;
}
for(int i=0;i<=25;i++)
dinamic[1][i] = 1;
for(int i=2;i<=n;i++){
for(int j=0;j<26;j++){
for(int k=0;k<26;k++){
if(adj[j][k] == 0){
dinamic[i][j]=(dinamic[i-1][k] + dinamic[i][j])%MOD;
}
}
}
}
int sum=0;
for(int i=0;i<26;i++)
sum=(dinamic[n][i] + sum)%MOD;
out<<sum<<'\n';
return 0;
}