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条)

报告相同问题?

悬赏问题

  • ¥15 平板录音机录音问题解决
  • ¥15 请问维特智能的安卓APP在手机上存储传感器数据后,如何找到它的存储路径?
  • ¥15 (SQL语句|查询结果翻了4倍)
  • ¥15 Odoo17操作下面代码的模块时出现没有'读取'来访问
  • ¥50 .net core 并发调用接口问题
  • ¥15 网上各种方法试过了,pip还是无法使用
  • ¥15 用verilog实现tanh函数和softplus函数
  • ¥15 Hadoop集群部署启动Hadoop时碰到问题
  • ¥15 求京东批量付款能替代天诚
  • ¥15 slaris 系统断电后,重新开机后一直自动重启