Cod sursa(job #236854)

Utilizator raica_cristiraica dumitru cristian raica_cristi Data 28 decembrie 2008 17:17:05
Problema Oz Scor 65
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.57 kb
#include<stdio.h>

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