递归求最大素因数(java)

前言

可能经常进群会问这个群号的最大素因数是多少,或者算法题中也会遇到。今天就写一下求最大质因数的模板。

分析

  • 首先分析,怎么求一个数的最大素因数。首先,我们以前求过最大因数,求最大因数的最暴力为2—n-1暴力查找 ,但是这样太超时了,后来发现在根号n前或者后某个区域查找就行了。因为找某个因数时候。n=a* b;a<=根号n;b>=根号n;所以只需查找到最小的因数就可以通过除法找到最大的因数。这只是查找因数的一个思路。

  • 至于什么是素因数呢。那么这个数肯定满足两个条件:1为质数。2为n的因数。那么我们如何从众多n的因数中找到最大的那个素因数呢?

举个例子

  • 对于8=2 * 4=2*(2*2);那么8的最大素因数是2;
  • 对于20=2 * 10=2*(2*5)那么20的最大素因数是5;

可以发现这个查找就是一个递归的过程。对于某个n,查找的最大素因数就是他的最大因数和最小因数的两个数的最大质因数。在往下调用的过程中,如果某个数是质数那么就不进行往下递归,(当然也可以进行剪枝优化,比如设置一个参数为已经找到素因数的最大值,当数值小于这个数就不进行递归减小程序的运算量,但是一般主要的循环到根号n不会超时)
下面附上代码:

private static int getmax(int a) {
	for(int i=2;i*i<a+1;i++)
	{
		if(a%i==0)
		{
		    return getmax(a/i)>getmax(i)?getmax(a/i):getmax(i);
		}	
	}
		return a;// 如果找不到因数他自己就是最大素因数
	}

如果对后端、爬虫、数据结构算法等感性趣欢迎关注我的个人公众号交流:bigsai

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员bigsai

喝杯咖啡压压惊!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值