Pagini recente » Istoria paginii runda/aaavram/clasament | Cod sursa (job #2808614) | Istoria paginii runda/rf__1/clasament | Istoria paginii runda/beginers/clasament | Cod sursa (job #626547)
Cod sursa(job #626547)
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main () {
int n, i, s, nr, div = 2, tmp;
int *divs = calloc (1000001, sizeof(int));
int temp;
freopen ("ssnd.in", "r", stdin);
freopen ("ssnd.out", "w", stdout);
while (div < 1000001)
{
if (divs[div] == 0)
{
divs[div] = 1;
temp = div * div;
while (temp > 0 && temp < 1000001 && divs[temp] == 0)
{
divs[temp] = 2;
temp += div;
}
}
if (div == 2)
div ++;
else
div += 2;
}
scanf ("%d", &n);
while (n--)
{
scanf ("%d", &tmp);
nr = 2;s = 1 + tmp;
for (i = 2; i < sqrt (tmp); i++)
if (divs[i] == 1 && tmp % i == 0)
{
s += i + tmp / i;
nr += 2;
}
printf ("%d %d\n", nr, s);
}
free (divs);
return 0;
}