题解 | #质数因子#

质数因子

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

编辑一下,看了别人的代码才醒悟过来。只要从2开始循环除,就可以保证每个因数都是质数了,就不用每个数都验证了。
唉,丢人。数论这块是完全不行啊。

实现本身不难,也不用排序,就是一直超时。只能优化算法。关键点在于,一是验证是否为质数时,循环到平方根即可,这个属于是数学知识了;二是当题目给出的是超巨大质数时的计算,加了个判定是否为质数,是的话直接输出的环节。
只能说果不其然,还真有个超巨大的素数。属于是勾心斗角了。
#include<stdio.h>
#include<math.h>

int judge(int a);

int main()
{
    int input;
    int x=2;
    scanf("%d", &input);
    while(input>1)
    {
        if(judge(input)==1)
        {
            printf("%d ", input);
            break;
        }
        if((input%x)==0&&judge(x)==1)
        {
            while((input%x)==0)
            {
                printf("%d ", x);
                input/=x;
            }
            x++;
        }
        else    x++;
    }
    return 0;
}

int judge(int a)
{
    int i;
    for(i=2; i<(int)sqrt(a)+1; i++)
    {
        if((a%i==0))    return 0;
    }
    return 1;
}


全部评论

相关推荐

头像
11-09 17:30
门头沟学院 Java
TYUT太摆金星:我也是,好几个华为的社招找我了
点赞 评论 收藏
分享
11-09 14:54
已编辑
华南农业大学 产品经理
大拿老师:这个简历,连手机号码和照片都没打码,那为什么关键要素求职职位就不写呢? 从上往下看,都没看出自己到底是产品经理的简历,还是电子硬件的简历? 这是一个大问题,当然,更大的问题是实习经历的描述是不对的 不要只是去写实习流程,陈平,怎么去开会?怎么去讨论? 面试问的是你的产品功能点,是怎么设计的?也就是要写项目的亮点,有什么功能?这个功能有什么难处?怎么去解决的? 实习流程大家都一样,没什么优势,也没有提问点,没有提问,你就不得分 另外,你要明确你投的是什么职位,如果投的是产品职位,你的项目经历写的全都是跟产品无关的,那你的简历就没用 你的面试官必然是一个资深的产品经理,他不会去问那些计算机类的编程项目 所以这种四不像的简历,在校招是大忌
点赞 评论 收藏
分享
6 收藏 评论
分享
牛客网
牛客企业服务