Cod sursa(job #2608811)

Utilizator Albert_GAlbert G Albert_G Data 1 mai 2020 19:31:53
Problema Lista lui Andrei Scor 10
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.07 kb
#include <fstream>

using namespace std;

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

int nrcuv[26][1001];
bool a[26][26];
const int mod = 104659;

void initializare()
{
    for(int i=0;i<26;i++)
    {
        nrcuv[i][2]=26;
        for(int j=0;j<26;j++)
        {
                if(a[i][j] || a[j][i])
                    nrcuv[i][2]--;
        }
    }
}

int main()
{
    int l,m,cnt=0;
    in>>l>>m;
    char x,y;
    for(int i=0;i<m;i++)
    {
        in>>x>>y;
        int nr=x-'a',nr2=y-'a';
        if(!a[nr][nr2])
        {
            a[nr][nr2]=1;
            cnt++;
        }
        if(!a[nr2][nr])
        {
            a[nr2][nr]=1;
            cnt++;
        }
    }
    initializare();
    for(int i=3;i<=l;i++)
    {
        for(int j=0;j<26;j++)
        {
            nrcuv[j][i]=(nrcuv[j][i-1]*26)%mod;
            nrcuv[j][i]-=cnt;
        }
    }
    long long rez=0;
    for(int i=0;i<26;i++)
        {
            rez+=nrcuv[i][l];
            rez=rez%mod;
        }
    out<<rez;
    return 0;
}