HDU_1299 Diophantus of Alexandria

原文链接:http://blog.csdn.net/grastyele/article/details/6678454

整数分解:

  任何一个正整数都可以表示成素数的x次方之积,所以本题就被转化成了求n ^2的素因子个数;

  先把n分解得到  n = p1^e1 * p2^e2  * ......*pr^er  其中p是< n 的素数那么n 的素因子, 则n的因子个数  k = (e1 + 1) * (e2 + 1) * (e3 + 1)*......

  所以:n ^2的因子数是k =  (2*e1+1) * (2*e2+1)* (2*e3+1)......

这个题还要注意一点就是当n是素数的时候,很显然 k *= 3,这样做得到的结果是题目要求的2倍

#include < stdio.h >
#include
< math.h >
#define max 50000
int num[max], prim[max];
int main()
{
int t, n, i, j, cnt, a, m, pim;
m
= 0 ;
for (i = 1 ; i < max; ++ i)
{
num[i]
= 1 ;
}
for (i = 2 ; i < max; ++ i) // 筛素数
{
if (num[i])
{
prim[m
++ ] = i;
for (j = i + i; j < max; j += i)
{
num[j]
= 0 ;
}
}
}
scanf(
" %d " , & t);
for (i = 1 ; i <= t; ++ i)
{
scanf(
" %d " , & n);
cnt
= 1 ;
for (j = 0 ; j < m; ++ j)
{
pim
= ( int ) sqrt(n * 1.0 ) + 1 ;
if (prim[j] > pim)
{
break ;
}
a
= 0 ;
while (n % prim[j] == 0 )
{
a
++ ;
n
/= prim[j];
}
cnt
*= ( 1 + 2 * a);
}
if (n > 1 ) // 当n是素数的时候
{
cnt
*= 3 ;
}
printf(
" Scenario #%d:\n " , i);
printf(
" %d\n " , (cnt + 1 ) / 2 );
printf(
" \n " );
}
return 0 ;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值