Pagini recente » Cod sursa (job #2113378) | Cod sursa (job #114272) | Cod sursa (job #2902888) | Cod sursa (job #2503493) | Cod sursa (job #2977118)
#include <bits/stdc++.h>;
#include <fstream>
#define INF 100001
#define MOD 104659
using namespace std;
ifstream fin("nrcuv.in");
ofstream fout("nrcuv.out");;
int n, m;
vector<set<int>> cuv(1000);// literele cu care litera i nu este compatibila
int dp[1005][500];// dp[n][i]=nr de cuvinte ce se pot forma cu n litere si care au ultima litera i
// dp[n][i]= suma dp[n-1][j], pentru toate j-urile compatibile cu i
// pe baza rezultatelor anterioare, pot sa aflu ce cuvinte pot forma stiind cate dintre ele au ultima litera, o anumita valoare
//!!!MOD
int main()
{
fin >> n >> m;
char x, y;
for (int i = 1; i<=m; i++) {
fin >> x >> y;
cuv[x].insert(y);
cuv[y].insert(x);
}
for (int i = 'a'; i <= 'z'; i++) {// cuvinte de o litera putem forma cu toate literele doar cate unul(nu avem asocieri de litere deci
// nu avem restrictii)
dp[1][i] = 1;
}
for (int i = 2; i <= n; i++) {
for (int j = 'a'; j <= 'z'; j++) {
for (int k = 'a'; k <= 'z'; k++) {
if (cuv[j].find(k) == cuv[j].end()) {
dp[i][j] = ( dp[i][j]%MOD+dp[i - 1][k]%MOD)%MOD;
}
}
}
}
// numarul de cuvinte ce se pot forma cu n litere, este suma dp[n][i]
// la final, cuvantul poate avea orice litera
int suma = 0;
for (int i = 'a'; i <= 'z'; i++) {
suma = (suma%MOD+ dp[n][i]%MOD)%MOD;
}
fout << suma;
fin.close();
fout.close();
return 0;
}