Cod sursa(job #138466)

Utilizator testelatugelu testelatu testelatu Data 18 februarie 2008 18:04:52
Problema Factoriale Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.33 kb
#include<stdio.h>
#define nmax 100
long long a[nmax];
int b[nmax];
int sol[nmax];

void inmulteste(int sol[nmax], int nr)
{
      int i, t = 0;
      for (i = 1; i <= sol[0] || t; i++, t /= 10)
              sol[i] = (t += sol[i] * nr) % 10;
      sol[0] = i - 1;
}


int main()
{
 freopen("factoriale.in","r",stdin);
 freopen("factoriale.out","w",stdout); 
 
 int n,k;
    
 long long solutie=1;    
    
 int i,j,aux; 
 int maxim1=0,maxim2=0;
   
 scanf("%d%d",&n,&k);
 
 for(i=1; i<=n; ++i){
 scanf("%d",&aux);
 a[aux]=1;
 
 if( aux >maxim1)
 maxim1=aux;
 
 }
        for(i=100,j=0; i>1; --i){
        if( a[i] )
        ++j;
        
        a[i]=j;
        }
        
 for(i=2; i<=nmax && a[i]; ++i){
 
 if( !b[i])
   for(j=i+i; j<=maxim1 && j<=nmax; j+=i){
   b[j]=1;
   a[j]*=j;
   a[i]+=(a[j]/i);
   }
}  
 sol[0]=1;
 sol[1]=1;
        
        for(i=2; i<=100 && i<=maxim1; ++i){    
           if( a[i] && !b[i]){
            
            if( a[i]!=k)
           { 
            if( a[i]<k )
            inmulteste(sol, (k-a[i])*i);
            else
            
            while( a[i]%k ){
            inmulteste( sol,i);
            ++a[i];}
            }
            }
           }
             
for(i=sol[0]; i>0; --i)
printf("%d",sol[i]);
printf("\n");



    return 0;
}