Cod sursa(job #2674520)

Utilizator BogdanFarcasBogdan Farcas BogdanFarcas Data 19 noiembrie 2020 16:22:10
Problema Lista lui Andrei Scor 0
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.8 kb
#include <iostream>
#include <queue>
#include <cmath>

using namespace std;

const int N=1001;
int n,m;
int dp[27][N],val[27];
bool ok[27][27];
char x,y;

int main()
{
    cin>>n>>m;
    for(int i=1;i<=m;i++)
    {
        cin>>x>>y;
        ok[x-'a'][y-'a']=ok[y-'a'][x-'a']=1;
    }
    for(int i=0;i<26;i++)
    {
        for(int j=0;j<26;j++)
        {
            if(ok[i][j])
            {
                val[i]++;
            }
        }
    }
    for(int i=0;i<26;i++)
    {
        dp[i][1]=1;
    }
    for(int i=0;i<26;i++)
    {
        for(int j=2;j<=n;j++)
        {
            dp[i][j]=(dp[i][j-1]+25-val[i])%104659;
        }
    }
    int ans=0;
    for(int i=0;i<26;i++)
    {
        ans+=dp[i][n]%104659;
    }
    cout<<ans%104659;
    return 0;
}