Pagini recente » Cod sursa (job #1146469) | Cod sursa (job #271731) | Cod sursa (job #2814914) | Cod sursa (job #381053) | Cod sursa (job #2210853)
#include <fstream>
#define MOD 104659
using namespace std;
char c1, c2;
int a[26][26];
int da[26], dc[26];
int n, m, i, j, k, sol;
int main () {
ifstream fin ("nrcuv.in");
ofstream fout("nrcuv.out");
fin>>n>>m;
for (i=1;i<=m;i++) {
fin>>c1>>c2;
a[c1-'a'][c2-'a'] = 1;
a[c2-'a'][c1-'a'] = 1;
}
for (j=0; j<26;j++) {
da[j] = 1;
}
for (i=2; i<=n; i++) {
/// calculez linia i din matricea d, adica numar cuvinte de lungime i
/// din cuvinte de lungime i-1 adica adaugand o litera
for (j=0;j<26;j++) {
/// calculez d[i][j] = cate siruri de lungime i se termina cu a j-a litera
dc[j] = 0;
for (k=0; k<26; k++)
if (a[k][j] == 0) {
dc[j] += da[k];
dc[j] %= MOD;
}
}
for (int j=0; j<26; j++)
da[j] = dc[j];
}
sol = 0;
for (i=0; i<26; i++){
sol += da[i];
sol %= MOD;
}
fout<<sol;
return 0;
}