Pagini recente » Cod sursa (job #155637) | Cod sursa (job #1296434) | Cod sursa (job #2967664) | Cod sursa (job #1292887) | Cod sursa (job #138466)
Cod sursa(job #138466)
#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;
}