Chinaunix首页 | 论坛 | 博客
  • 博客访问: 223172
  • 博文数量: 68
  • 博客积分: 3120
  • 博客等级: 中校
  • 技术积分: 715
  • 用 户 组: 普通用户
  • 注册时间: 2008-03-08 09:53
文章分类
文章存档

2012年(29)

2011年(3)

2010年(18)

2009年(18)

我的朋友

分类: C/C++

2011-04-26 22:25:13

问题:

The prime factors of 13195 are 5, 7, 13 and 29.

What is the largest prime factor of the number 600851475143 ?


答案:6857

#include
#include

int main(void)
{
    long int n = 600851475143L;
    int lastFactor = 2;

    if(n%2==0){
        lastFactor = 2;
        n = n/2;
        while(n%2==0)
            n = n/2;
    }   
    else
        lastFactor = 1;
    int factor = 3;

    int maxFactor = sqrt(n);
    while(n>1 && factor<=maxFactor){
        if(n%factor==0){
            n = n/factor;
            lastFactor = factor;
            while(n/factor==0)
                n = n/factor;
            maxFactor = sqrt(n);
        }
        factor += 2;
    }

    if(n==1)
        printf("%d\n", lastFactor);
    else
        printf("%d\n", n);

    return 0;
}


阅读(700) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~