m0_66394588 2022-02-07 01:46 采纳率: 91.5%
浏览 48
已结题

请问这种判断是否为质数的方法的原理是什么呢?

#include<stdio.h>
#include<stdbool.h>

int main()
{
    int i,num;
    _Bool flag=1;

printf("请输入一个整数:");
scanf("%d",&num);

for(i=2;i<=num/2;i++)
{
    if(num%i==0)
    {
        flag=0;
    }
 } 
 if(flag)
 {
     printf("%d是一个素数!\n",num);
 }
 else
 {
     printf("%d不是一个素数!\n",num);
 }
 return 0;

}

  • 写回答

3条回答 默认 最新

  • _GX_ 2022-02-07 05:39
    关注

    给定一个数x>=2,如果x只能被1和x整除,那么x就是质数,否则就不是质数。换句话说,如果能找到一个数1<a<x且x能被a整除,那么x就不是质数。
    如果x能被a整除,令b=x/a,那么x也能被b整除。假设a<=b,代入b得到a<=x/a,即a^2<=x,因此a<=sqrt(x)。故验证一个数x是否是质数,只需要验证x不能被(1, sqrt(x)]之间的任意整数整除。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 2月16日
  • 已采纳回答 2月8日
  • 创建了问题 2月7日

悬赏问题

  • ¥15 csmar数据进行spss描述性统计分析
  • ¥15 各位请问平行检验趋势图这样要怎么调整?说标准差差异太大了
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题
  • ¥15 wpf界面一直接收PLC给过来的信号,导致UI界面操作起来会卡顿
  • ¥15 init i2c:2 freq:100000[MAIXPY]: find ov2640[MAIXPY]: find ov sensor是main文件哪里有问题吗
  • ¥15 运动想象脑电信号数据集.vhdr
  • ¥15 三因素重复测量数据R语句编写,不存在交互作用
  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?