Cod sursa(job #804210)

Utilizator socheoSorodoc Ionut socheo Data 29 octombrie 2012 01:15:14
Problema Lista lui Andrei Scor 10
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.82 kb
#include <iostream>
#include <vector>
#include <cstdio>
using namespace std;

char q, w;
int n, m;
int a[1002][28];
bool ver[30][30];

int main()
{
    freopen("nrcuv.in", "r", stdin);
    freopen("nrcuv.out", "w", stdout);
    scanf("%d%d", &n, &m);
    for(int i = 1; i <= m; i++)
    {
        scanf("%c %c\n", &q, &w);
        ver[q - 'a' + 1][w - 'a' + 1] = 1;
        ver[w - 'a' + 1][q - 'a' + 1] = 1;
    }

    for(int i = 1; i <= 26; i++)
        a[1][i] = 1;
    for(int i = 2; i <= n; i++)
        for(int j = 1; j <= 26; j++)
        {
            for(int k = 1; k <= 26; k++)
                if(ver[j][k] == 0 )
                    a[i][j] = (a[i][j] + a[i-1][k]) % 104659;
        }

    int sum = 0;
    for(int i = 1; i <= 26; i++)
        sum = (sum + a[n][i]) % 104659;
    printf("%d", sum);
    return 0;
}