Cod sursa(job #466135)

Utilizator Marius96Marius Gavrilescu Marius96 Data 26 iunie 2010 11:07:22
Problema Colorare3 Scor 70
Compilator cpp Status done
Runda Stelele Informaticii 2010, gimnaziu si clasa a IX-a, Ziua 2 Marime 0.8 kb
#include <cstdio>
#include <vector>
#define MODD 1000000007ULL
using namespace std;
int n,k;
vector<int> v[100005];
       int col[100005];
       int fr[100005];
      bool us[100005];
unsigned long long int ans=1;
void BF(int nr){
    us[nr]=1;
    for(int i=col[nr]-fr[nr]+1;i<=col[nr];i++)
        ans=(ans*i)%MODD;
    for(unsigned int i=0;i<v[nr].size();i++){
        int x=v[nr][i];
        if(!us[x]){
            col[x]--;
            fr[x]--;
            BF(x);
        }
    }
}
int main(){
    freopen("colorare3.in","r",stdin);
    freopen("colorare3.out","w",stdout);
    int x,y;
    scanf("%d%d",&n,&k);
    for(int i=0;i<n-1;i++){
        scanf("%d%d",&x,&y);
        fr[x]++;fr[y]++;
        v[x].push_back(y);v[y].push_back(x);
        col[i]=k;
    }
    BF(1);
    printf("%llu",ans);
    return 0;
}