Analyse:
用数组pd[4](prime divisor)记录质因数2,3,5,7的次数。n的因数都可表示为n=2^pd[0]*3^pd[1]*5^pd[5]*7^pd[3],只要有一个指数不与对应底数的指数相等,两个质因数就是不相等的。因此,题目的意思就是求2,3,5,7的指数的组合。(注意指数可以为0)因此因数个数为(pd[0]+1)*(pd[1]+1)*(pd[2]+1)*(pd[3]+1)。
View Code
 1 #include<stdio.h>
2 main()
3 {
4 __int64 n;
5 __int64 count;
6 __int64 pd[4];//2,3,5,7质因数个数
7 while(scanf("%I64d",&n)&&n)
8 {
9 for(pd[0]=0;n%2==0;pd[0]++,n/=2);
10 for(pd[1]=0;n%3==0;pd[1]++,n/=3);
11 for(pd[2]=0;n%5==0;pd[2]++,n/=5);
12 for(pd[3]=0;n%7==0;pd[3]++,n/=7);
13 count=(pd[0]+1)*(pd[1]+1)*(pd[2]+1)*(pd[3]+1);
14 printf("%I64d\n",count);
15 }
16 }

相关文章:

  • 2021-10-24
  • 2021-04-11
  • 2021-04-06
  • 2021-04-17
  • 2021-11-16
  • 2021-08-08
  • 2022-02-22
  • 2021-06-08
猜你喜欢
  • 2021-08-04
  • 2021-08-16
  • 2021-04-16
  • 2021-04-26
  • 2021-06-26
  • 2021-06-01
  • 2021-07-23
相关资源
相似解决方案