Project Euler - 3

欧拉项目 题目3
problem:  The prime factors of 13195 are 5, 7, 13 and 29. What is the largest prime factor of the number 600851475143 ?
solution:   这个问题是求质因子(n可以被600851475143整除,且自身是一个质数)。我们知道最小的质数是2,那么从2开始,一直用600851475143 整除factor,如果能整除就一直整除,这样可以保证这个较小质数的倍数不会再出现,比如一直除2,那么2最后除尽之后,不会再出现4的倍数,8的倍 数。 n /= facotr, 可以将要求的数一直变小,这样可以节省很多开销。最后当 n == factor 时,算得 n == 1, 结束循环, 由于最后一次factor多自加了一次,所以最后return需要先自减一次。




public static int findLargestPrimeFactor(long n) {
		int factor = 2;
		while (n > 1) {
			if (0 == n % factor) {
				while (0 == n % factor) {
					n /= factor;
				}
			}
			factor++;
		}
		factor -= 1;
		return factor;
	}


optimization: factor += (factor==2?1:2); 由于整除2的时候一定会把n整除为奇数,所以后面没有再自加为偶数的必要,所以选择自加2. 但是从第 一次2过渡到3时需要自加一,所以修改自加部分为:factor += (factor==2?1:2);

	public static int findLargestPrimeFactor2(long n) {
		int factor = 2;
		while (n > 1) {
			if (0 == n % factor) {
				while (0 == n % factor) {
					n /= factor;
				}
			}
			factor += (factor==2?1:2);
		}
		factor -= 2;
		return factor;
	}




该博客是本人为平时练习算法积累的笔记,只为平时积累和交流使用,本人能力有限,有些代码非本人思路,特此声明!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值