题解 | #质数因子#

质数因子

http://www.nowcoder.com/practice/196534628ca6490ebce2e336b47b3607

此题通过从2开始去找数n的质因数,用例输入2000000014过不了,因为2000000014的质因数为2和1000000007,后面是一个非常大的素数,在for循环中就相当于直接遍历1000000007了,会超时。通过引入判断是否为素数来进行优化。素数的判断也是经过了优化的,参考我的另一篇文章《利用孪生素数判断是否为素数》,地址:https://blog.nowcoder.net/n/52c9640ea14a4330a842e783429698b5

#include <stdio.h>
#include <stack>
#include <math.h>

using namespace std;

bool is_prime(long n)
{
    if(n==2 || n==3) return false;
    if(n%6!=1 && n%6!=5) return false;

    //到这里,留下来的n只可能是6N+1或者6N+5;
    long div = 5;
    long t = n/div;
    while(t>=div)
    {
        //n可能是(6N+1)与(6N+5)两个因子的乘积,故需要在这里进行判断;
        if(n%div==0 || n%(div+2)==0) return false;
        div += 6;
        t = n/div;
    }
    return true;
}

void fun(long n)
{
    for(long i=2;i<=n;i++)
    {
        //用例输入2000000014过不了,这里通过判断是否为素数来提前结束;
        if(is_prime(n))
        {
            printf("%ld",n);
            return;
        }

        while(n % i == 0)
        {
            printf("%d ",i);
            n /= i;


        }
    }
}

int main()
{
    long n;
    while(scanf("%ld",&n) != EOF)
    {
        fun(n);
    }
    return 0;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-08 13:15
点赞 评论 收藏
分享
见见123:简历没有啥问题,是这个社会有问题。因为你刚毕业,没有工作经历,现在企业都不要没有工作经历的。社会病了。
点赞 评论 收藏
分享
嵐jlu:我是山川🐔里🐔🧱的,阿里系简历全过; 你这简历一看就还是半成品啊,没有荣誉经历奖项什么的吗?
投递阿里巴巴集团等公司10个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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