Pagini recente » Cod sursa (job #2448622) | Cod sursa (job #376135) | Cod sursa (job #976962) | Cod sursa (job #2272725) | Cod sursa (job #625630)
Cod sursa(job #625630)
#include <stdio.h>
#include <stdlib.h>
int main()
{
char v[1000001];
//int n,cate = 0,i,j;
//FILE *f = fopen("ciur.in","r");
//freopen("ciur.out","w",stdout);
// fscanf(f,"%i",&n);
//fclose(f);
int i,j;
for (i=2; i <= 1000000; i++) {
v[i] = '1';
}
for (i=2; i <= 1000000; i++) {
if (v[i] == '1') {
// ++cate;
for (j=i+i; j <= 1000000; j+=i) {
v[j] = '0';
}
}
}
//printf("%i",cate);
FILE *f = fopen("ssnd.in", "r"), \
*g = fopen("ssnd.out", "w");
long long int n,nr,nrl,jj,sum,mod = 9973;
long long int x,p = 1;
fscanf(f, "%llu", &n);
for (i = 0; i < n; i++)
{
fscanf(f,"%llu", &x);
j = 2;
jj = 1;
sum = 1;
nr = 1;
nrl = 0;
p=1;
while (x != 1)
{//printf("x = %i\n",x);
// printf("j = %i", j);
if (x % j == 0)
{
x = x / j;
p *= j;
nrl++;
}
else
{
nr *= (nrl+1) ;
sum =(1LL * sum *(p * j -1)/(j - 1)) % mod;
p = 1;
nrl = 0;
j++;
while (v[j] == '0') j++;
}
}
nr *= (nrl+1) ;
sum = (1LL*sum*(p * j -1)/(j - 1)) % mod;
p = 1;
nrl = 0;
fprintf(g, "%llu %llu\n", nr, sum);
}
fclose(f);
fclose(g);
return 0;
}