Pagini recente » Cod sursa (job #1775459) | Cod sursa (job #1368469) | Cod sursa (job #1633784) | Cod sursa (job #3206931) | Cod sursa (job #2793399)
#include <fstream>
#include <cmath>
using namespace std;
ifstream fin("ssnd.in");
ofstream fout("ssnd.out");
long long n,i,j,x,nr,d,s,p,k;
char ciur[1000001];
int prim[1000001];
int main()
{
fin >>n;
ciur[1]=1;
ciur[0]=1;
for(i=2;i<=1000000;i++)
{
if(ciur[i]==0)
{
k++;prim[k]=i;
for(j=i*i;j<=1000000;j+=i)
{
ciur[j]=1;
}
}
}
for (i=1;i<=n;i++)
{
fin >>x;
k=1;
d=prim[k];
nr=1;
s=1;
while(prim[k]*prim[k]<=x)
{
p=0;
while (x%d==0)
{
p++;
x=x/d;
}
if (p!=0) {
nr=nr*(p+1);
s=s*(pow(d,p+1)-1)/(d-1);
s=s%9973;
}
k++;
d=prim[k];
}
if (x>1)
{
nr=nr*2;
s=s*(x*x-1)/(x-1);
s=s%9973;
}
fout <<nr<<" "<<s%9973<<'\n';
}
return 0;
}