Cod sursa(job #236835)

Utilizator raica_cristiraica dumitru cristian raica_cristi Data 28 decembrie 2008 16:55:09
Problema Oz Scor 5
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.92 kb
#include<stdio.h>

int check(int a,int b)
{   int c;
    while(a)
    {
            c=b%a;
            b=a;
            a=c;
}
if(a)
return 1;
return 0;
}
int main ()
{
    freopen("oz.in","r",stdin);
    freopen("oz.out","w",stdout);
    int n,m,i,k;
    int x,b,c;
    scanf("%d%d",&n,&m);
    long long int a[n];
    for(i=1;i<=n;i++)
    a[i]=1;
    for(i=1;i<=m;i++)
    {
                     scanf("%d%d%d",&x,&b,&c);
                     if(check(c,a[x])==0)
                     a[x]*=c;
                     if(check(c,a[b])==0)
                     a[b]*=c;
                     if(a[x]>2000000000 || a[b]>2000000000)
                     {printf("-1\n");
                     return 0;
                     }
                     }
                     for(i=1;i<=n;i++)
                     printf("%d\n",a[i]);
                     return 0;
                     }