判断是否为素数时,只除到根号数的原因是什么?

 我来答
刺任芹O
2022-11-16 · TA获得超过6.2万个赞
知道顶级答主
回答量:38.7万
采纳率:99%
帮助的人:9070万
展开全部

判断是否为素数时,只除到根号数的原因是:

因为若m整除n(其中n>根号m)则m=n*k。

因为若m不整除从1除到根号m的数它就不可能整除根号m后面的数。

如果根号m有小于SQRT(m)的因子X,那么N必定有大于SQRT(m)的因子Y与X对应。

而且X*Y=m。

所以只需要枚举1..SQRT(m)的数即可,还要考虑m为完全平方数的特殊情况。

比如:64

2*32=64 8*8=64。

如果再往后面算如32*2=64其实已经和前面对应了。

不过就是顺序反了而这个临界点就是开方的那个数。

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式