Pagini recente » Cod sursa (job #1705255) | Cod sursa (job #1577723) | Cod sursa (job #357711) | Cod sursa (job #1240022) | Cod sursa (job #2476923)
#include <bits/stdc++.h>
#define NMAX 1005
#define CMAX 150
#define MOD 104659
using namespace std;
ifstream fin("nrcuv.in");
ofstream fout("nrcuv.out");
int dp[NMAX][CMAX], n, k, mat[NMAX][CMAX];
char a, b;
int main(){
fin>>n>>k;
for(int i = 1; i <= k; ++i){
fin>>a>>b;
mat[a][b] = mat[b][a] = 1;
}
for(int i = 'a'; i <= 'z'; ++i)
dp[1][i] = 1;///exista un sir de lungime 1, avand ultimul element i
for(int i = 2; i <= n; ++i){
for(int a = 'a'; a <= 'z'; ++a){
for(int b = 'a'; b <= 'z'; ++b){
if(mat[a][b] == 0){
dp[i][b] += dp[i-1][a];
dp[i][b] %= MOD;
}
}
}
}
int ans = 0;
for(int i = 'a'; i <= 'z'; ++i){
ans += dp[n][i];
ans %= MOD;
}
fout<<ans;
}