// 25用筛选法求1-1000之内的素数.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
#include <iostream>
#include <cmath>
#include <stdlib.h>
#include <iomanip>
using namespace std;
int main()
{
int i, k, a[1001];
for (i = 2; i <= 1000; i++) a[i] = 1;
float s = sqrt(float(1000));
for(i = 2; i <= s; i++)
if (a[i] == 1)
{
k = 2 * i;
while (k <= 1000)
{
a[k] = 0;
k = k + 1;
}
}
for (i = 2; i <= 1000; i++)
if (a[i] == 1)
cout << setw(5) << i;
}
求解释这个代码错在哪里?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- qzjhjxj 2022-02-12 11:49关注
代码修改如下,供参考:
// 25用筛选法求1-1000之内的素数.cpp : 此文件包含 "main" 函数。 //程序执行将在此处开始并结束。 #include <iostream> #include <cmath> #include <stdlib.h> #include <iomanip> using namespace std; int main() { int i, k, a[1001]={0}; //修改 //for (i = 2; i <= 1000; i++) a[i] = 1; int s = (int)sqrt(1000.0);//float s = sqrt(float(1000)); for(i = 2; i <= s; i++) { for(k = 2;k*i < 1001; k++)//if (a[i] == 1) a[i*k] = 1; //{ //k = 2 * i; //while (k <= 1000) //{ //a[k] = 0; //k = k + 1; //} } for (i = 2; i <= 1000; i++) if (a[i] == 0) //if (a[i] == 1) cout << setw(5) << i; return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥17 pro*C预编译“闪回查询”报错SCN不能识别
- ¥15 微信会员卡接入微信支付商户号收款
- ¥15 如何获取烟草零售终端数据
- ¥15 数学建模招标中位数问题
- ¥15 phython路径名过长报错 不知道什么问题
- ¥15 深度学习中模型转换该怎么实现
- ¥15 HLs设计手写数字识别程序编译通不过
- ¥15 Stata外部命令安装问题求帮助!
- ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
- ¥15 TYPCE母转母,插入认方向