这是一段判断素数的代码,但是不懂他是怎么判断出来的,可以详细解释一下吗?谢谢
3条回答 默认 最新
- qzjhjxj 2022-11-07 21:31关注
若所给定的数 j 不是素数,那么存在不等于 1 的两个约数x1 和 x2,并且满⾜x1 >= sqrt(j),x2 <= sqrt(j)。因此可直接搜索范围从2到sqrt(j)就可以, 使得搜索范围减少。代码里根据这个数学原理,从 i = 2 开始寻找直到 i = sqrt(j) ,如果 j 不是素数,循环结束后 j > k 必定成立,输出 j 是素数的判断,反之,循环时找到 j 的因子,循环被break; 提前结束,此时必定 i <= k , j 就不是素数了。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥15 微信会员卡等级和折扣规则
- ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
- ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
- ¥15 gdf格式的脑电数据如何处理matlab
- ¥20 重新写的代码替换了之后运行hbuliderx就这样了
- ¥100 监控抖音用户作品更新可以微信公众号提醒
- ¥15 UE5 如何可以不渲染HDRIBackdrop背景
- ¥70 2048小游戏毕设项目
- ¥20 mysql架构,按照姓名分表
- ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分