Cod sursa(job #3338538)

Utilizator CC2023Cezar Cirjau CC2023 Data 3 februarie 2026 20:34:08
Problema Lista lui Andrei Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.79 kb
#include <fstream>

using namespace std;
ifstream cin("nrcuv.in");
ofstream cout("nrcuv.out");

int n, m, dp[27][1001], p[27][27], x, y, s;
char c;
int main()
{
    cin>>n>>m;
    for(int i=0; i<m; i++)
    {
        cin>>c;
        x=int(c-'a');
        cin>>c;
        y=int(c-'a');
        p[x][y]=1;
        p[y][x]=1;
    }
    for(int i=0; i<26; i++)
    {
        dp[i][1]=1;
    }
    for(int i=2; i<=n; i++)
    {
        for(int c1=0; c1<26; c1++)
        {
            dp[c1][i]=0;
            for(int c2=0; c2<26; c2++)
            {
                if(p[c1][c2]==0)
                    dp[c1][i]=(dp[c1][i]+dp[c2][i-1])%104659;
            }
        }
    }
    for(int i=0; i<26; i++)
    {
        s=(s+dp[i][n])%104659;
    }
    cout<<s;
    return 0;
}