题解 | #约数的个数#

约数的个数

http://www.nowcoder.com/practice/04c8a5ea209d41798d23b59f053fa4d6

#include<iostream>
#include<cstdio>
#include<vector>
using namespace std;
const int MAXN=1000;
const int MAXNum=4e4;
bool IsPrime[MAXNum];
vector<int> Prime;
void Select(){
    for(int i=0;i<MAXNum;++i){
        IsPrime[i]=true;
    }
    IsPrime[0]=IsPrime[1]=false;
    for(int i=2;i<MAXNum;++i){
        if(IsPrime[i]){
            Prime.push_back(i);
            for(int j=i*i;j<MAXNum;j+=i){
                IsPrime[j]=false;
            }
        }
    }
}
int Num_Divisor(int &n){
    int number=1;
    int temp=n;
    for(int i=0;i<Prime.size()&&Prime[i]<temp;++i){
        int num_prime=0;
        while(n%Prime[i]==0){
            ++num_prime;
            n/=Prime[i];
        }
        number*=(num_prime+1);
    }
    return n==1?number:2*number;
}
int main(){
    int n;
    int array[MAXN];
    Select();
    while(scanf("%d",&n)!=EOF){
        for(int i=0;i<n;++i){
            scanf("%d",&array[i]);
        }
        for(int i=0;i<n;++i){
            printf("%d\n",Num_Divisor(array[i]));
        }
    }
    return 0;
}

全部评论

相关推荐

02-01 12:05
复旦大学 Java
腾讯的提前批大概率应该是没有笔试的,但是这个时候有相当部分的同学简历估计都没有准备好,没准备好的同学也不用急,大部分都是3月之后开,这个时候开的绝大多数都是神仙打架,问的东西也比较难,打算投递的同学也多看下计算机网络和操作系统,腾讯对这部分的知识问的比较多。另外多刷下牛客的热门题库,刷题注意刷ACM模式,和牛客的周赛题,腾讯有的部门会从这里面出原题。我是@程序员花海关注我,带你了解更多校招资讯!
程序员花海:还没有来得及准备的同学可以看下学习路线:https://www.nowcoder.com/discuss/824693499982315520?sourceSSR=users算法题:https://www.nowcoder.com/feed/main/detail/20e7a999fa04485b88340a274411ca0d?sourceSSR=users八股文:https://www.nowcoder.com/discuss/833102362771251200?sourceSSR=users简历书写方式:https://www.nowcoder.com/discuss/839907820706205696?sourceSSR=users都是以前在牛客发的文章~
软开人,秋招你打算投哪些...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务