链接:
https://www.nowcoder.com/acm/contest/90/F
来源:牛客网
来源:牛客网
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<math.h>
#define MAX 40005
int prime[MAX];
int vis[MAX];
int idx;
int cal(int n){
int ret=1;
int syz[MAX];
memset(syz,0,sizeof(syz));
for(int i=2;i*i<=n;i++){
while(n%i==0) n/=i,syz[i]++;
ret*=(syz[i]*2+1);///约数个数公式
}
if(n>1) syz[n]++,ret*=3;///如果n本身是质数
return ret;
}
int main()
{
int Case;
int ca,n,ans;
scanf("%d",&Case);
for(ca=1;ca<=Case;ca++)
{
scanf("%d",&n);
ans=cal(n);
printf("Scenario #%d:\n",ca);
printf("%d\n\n",(ans+1)/2);
}
return 0;
}
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 32768K,其他语言65536K
64bit IO Format: %lld
空间限制:C/C++ 32768K,其他语言65536K
64bit IO Format: %lld
题目描述
给定n,求1/x + 1/y = 1/n (x<=y)的解数。(x、y、n均为正整数)
输入描述:
在第一行输入一个正整数T。 接下来有T行,每行输入一个正整数n,请求出符合该方程要求的解数。 (1<=n<=1e9)
输出描述:
输出符合该方程要求的解数。
思路:构造x=n+a,y=n+b,易得n^2=a*b;所以题目就变成了找n^2的因子对个数。设n的因子个数为p,则ans=(p+1)/2;