历年考研复试专题-质因数的个数

质因数的个数

题目描述

求正整数N(N>1)的质因数的个数。 相同的质因数需要重复计算。如120=2*2*2*3*5,共有5个质因数。

输入描述:

可能有多组测试数据,每组测试数据的输入是一个正整数N,(1<N<10^9)。

输出描述:

对于每组数据,输出N的质因数的个数。

示例1

输入

120

输出

5

解题思路

           本题为打表题,由于数据为10^9开根,因此保存质数表中 最大的质数pr <=100000个即可。因此我们进行打表,筛选质数,然后对输入的数据进行分解即可。

样例代码

#include <iostream>
#include <cmath>
#define rep(i,s,e) for(int i = s;i<e;i++)
using namespace std;
typedef long long ll;
const int maxn = 100000;
int p[10000];
int ct = 0;
bool vis[maxn];
void getP(){
    rep(i,0,maxn) vis[i] = true;
    vis[2] = true;
    rep(i,2,maxn){
        if(vis[i]){
            for(int j = i+i;j<maxn;j+=i){
                vis[j] = false;
            }
        }
    }
    rep(i,2,maxn){
        if(vis[i]) p[ct++] = i;
    }
    return ;
}
int getI(ll n){
    int t = sqrt(n);
    int sum = 0;
    rep(i,0,ct){
        int pr = p[i];
        if(n<pr||n==0){
            break;
        }else{
            if(n%pr==0&&n!=0){
                while(n%pr==0){
                    sum++;
                    n/=pr;
                    //cout<<pr<<endl;
                }
            }
        }
    }
    if(n>2) sum++;
    return sum;
}
int main()
{
    ll n;
    getP();
    while(cin>>n){
        cout<<getI(n)<<endl;
    }
}

猜你喜欢

转载自blog.csdn.net/hnust_yangjieyu/article/details/82830246