Cod sursa(job #2977118)

Utilizator mati.coldea@gmail.comMatei Coldea [email protected] Data 10 februarie 2023 20:16:17
Problema Lista lui Andrei Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.56 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);// 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;
}