Cod sursa(job #2977115)

Utilizator mati.coldea@gmail.comMatei Coldea [email protected] Data 10 februarie 2023 20:10:41
Problema Lista lui Andrei Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.01 kb
#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);
int val[1005];
int dp[1005][500];
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++) {
        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;
                }

            }

        }

    }
    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;
}