Cod sursa(job #575041)

Utilizator dtoniucDaniel Toniuc dtoniuc Data 7 aprilie 2011 20:25:00
Problema Lista lui Andrei Scor 40
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.58 kb
#include <iostream>
#include <fstream>
using namespace std;
int T[27][27],v[27][10002],n,m;
int main ()
{
	char a,b;
	ifstream fin("nrcuv.in");
	ofstream fout("nrcuv.out");
	fin>>n>>m;
	for(int i=1;i<=m;i++)
	{
		fin>>a>>b;
		T[(a+1)-'a'][(b+1)-'a']=T[(b+1)-'a'][a-'a'+1]=1;
	}
	for(int i=1;i<=26;i++)
		v[i][1]=1;
	for(int i=1;i<=n;i++)
		for(int j=1;j<=26;j++)
			for(int k=1;k<=26;k++)
				if(T[j][k]==0)
				{
					v[j][i]+=v[k][i-1];
					v[i][j]%=104659;
				}
	int s=0;
	for(int i=1;i<=26;i++)
	{
		s+=v[i][n];
		s%=104659;
	}
	fout<<s;
	return 0;
}