素数求解的多种境界有哪些,素数求解的多种境界是

  素数求解的多种境界有哪些,素数求解的多种境界是

  #每日照片分享#

  请输出从100到200的所有质数。

  通过试除法输出素数:

  #包含stdio.h

  int main()

  {

  int num=0;

  int count=0;

  for(num=100;num=200数字)

  {

  int j;

  for(j=2;j numj)

  {

  if (num % j==0)

  打破;

  }

  if (j==num)

  {

  printf(%d ,j);

  数数;

  }

  }

  printf(\ncount=%d\n ,计数);

  返回0;

  }运行结果如下:

  虽然结果是正确的,但这段代码可以进一步优化:

  使用平方根函数sqrt()。

  如果一个数不是质数,那么一定有num=a*b,并且其中一个数一定小于

  Sqrt(num),这是完成代码的方法:

  #包含stdio.h

  #include math.h //对应sqrt的库函数

  int mian()

  {

  int num//如果num不是质数,那么一定有num=a*b,而且一定有其中一个

  int count=0;//数字小于sqrt(num),也有大于sqrt(num)的数字

  for(num=100;num=200数字)

  {

  int j;

  for(j=2;j=sqrt(num);J) //sqrt是平方根函数

  {

  if (num % j==0)

  打破;

  }

  if (j sqrt(num))

  {

  printf(%d ,j);

  数数;

  }

  }

  printf(\ncount=%d\n ,计数);

  返回0;

  }这样计算量减少一半以上,运行效率更高。

  其实我们也知道偶数不一定是质数,可以通过跳过所有偶数来进一步减少计算量。如下所示:

  #包含stdio.h

  #包含数学. h

  int mian()

  {

  int num

  int count=0;

  for(num=101;num=200数量=2)

  {

  int j;

  for(j=2;j=sqrt(num);j)

  {

  if (num % j==0)

  打破;

  }

  if (j sqrt(num))

  {

  printf(%d ,j);

  数数;

  }

  }

  printf(\ncount=%d\n ,计数);

  返回0;

  }100是偶数,可以直接跳过,使num=101,然后通过一个循环使后面所有的num=2,这样就可以直接跳过偶数,进一步减少计算量。

  感谢阅读

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

相关文章阅读

  • office2010激活密钥大全 怎么永久激活office2010
  • project2010产品密钥免费_project2010激活密钥永久激活码
  • c语言调用退出函数 c语言退出整个程序怎么写
  • c语言中怎么给函数初始化 c语言的初始化语句
  • c语言编写函数计算平均值 c语言求平均函数
  • chatgpt是什么?为什么这么火?
  • ChatGPT为什么注册不了?OpenAI ChatGPT的账号哪里可以注册?
  • OpenAI ChatGPT怎么注册账号?ChatGPT账号注册教程
  • chatgpt什么意思,什么是ChatGPT ?
  • CAD中怎么复制图形标注尺寸不变,CAD中怎么复制图形线性不变
  • cad中怎么创建并使用脚本文件,cad怎么运行脚本
  • cad中快速计算器的功能,cad怎么快速计算
  • cad中快速修改单位的方法有哪些,cad中快速修改单位的方法是
  • cad中心点画椭圆怎么做,cad轴测图怎么画椭圆
  • CAD中常用的快捷键,cad各种快捷键的用法
  • 留言与评论(共有 条评论)
       
    验证码: