描述
求正整数N(N>1)的质因数的个数。 相同的质因数需要重复计算。如120=2*2*2*3*5,共有5个质因数。
输入描述:
可能有多组测试数据,每组测试数据的输入是一个正整数N,(1<N<10^9)。
输出描述:
对于每组数据,输出N的质因数的个数。
示例1
输入:
120
输出:
5
代码如下:
import java.util.Scanner;/** 质因数的个数*/
public class PrimeFactorNum {public static void main(String[] args){Scanner sc = new Scanner(System.in);while(sc.hasNext()){int n = sc.nextInt();int nums = 0;//从最小的质数开始,如果i为合数,则其非1和本身的因子一定不能整除n,i也不能整除n,会排除所有合数数for(int i=2;i<=n;i++){while(0 == n%i){n = n/i;nums++;}}System.out.println(nums);}}
}