Cod sursa(job #2674535)

Utilizator BogdanFarcasBogdan Farcas BogdanFarcas Data 19 noiembrie 2020 16:38:03
Problema Lista lui Andrei Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.81 kb
#include <fstream>

using namespace std;

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

const int N=1001;
int n,m;
int dp[N][27],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++)
    {
        dp[1][i]=1;
    }
    for(int i=2;i<=n;i++)
    {
        for(int j=0;j<26;j++)
        {
            for(int k=0;k<26;k++)
            {
                if(!ok[j][k])
                {
                    dp[i][j]+=dp[i-1][k];
                    dp[i][j] %= 104659;
                }
            }
        }
    }
    int ans=0;
    for(int i=0;i<26;i++)
    {
        ans+=dp[n][i]%104659;
    }
    cout<<ans%104659;
    return 0;
}