Pagini recente » Cod sursa (job #1445003) | Cod sursa (job #1227228) | Cod sursa (job #2195018) | Cod sursa (job #2749910) | Cod sursa (job #2608811)
#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;
}