Grooter 2016-09-03 01:33 采纳率: 100%
浏览 1273
已采纳

一个简单程序出错了求纠错,谢谢

我写了一个求1000-10000素数的程序,代码去图片,但为什么求出的从是9701后的所有数?图片

#include "stdafx.h"
#include
#include

int calculate(int i)

{
int judge;
for (judge = 2; judge < i; judge++) //穷举i的所有除数
{
if (i%judge == 0)

{
return 0; //不是素数
}
else if (i!=judge+1) //判断i有没有被所有除数除完 如果除完都没有余数就返回1 即这个数十素数! 如果没有除完继续循环除!
continue;
else
return 1;
}
}

int main()
{
int i;
for (i = 1000; i < 10000; i++) //穷举所有i
if (calculate(i) == 1)

printf("%d\n", i); //输出素数!
system("pause");

  • 写回答

8条回答 默认 最新

  • 登天蚂蚁 2016-09-03 03:31
    关注

    老实说,这代码问题太多,判断i是否是素数的循环里,Target范围不用从2到达i,到达i平方根即可,其次,i跟1,2的比较没用,
    再次,target不用累加,如果i是素数,判断到i的平方根即可确定是素数,如果i不是素数,则必然可以由素数的乘积构成,所以target
    的取值只需全部取素数即可

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

报告相同问题?

悬赏问题

  • ¥30 vmware exsi重置后的密码
  • ¥15 易盾点选的cb参数怎么解啊
  • ¥15 MATLAB运行显示错误,如何解决?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容
  • ¥15 UE5#if WITH_EDITOR导致打包的功能不可用
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题
  • ¥20 yolov5自定义Prune报错,如何解决?
  • ¥15 电磁场的matlab仿真
  • ¥15 mars2d在vue3中的引入问题