鱼C论坛

 找回密码
 立即注册
查看: 1759|回复: 4

[已解决]用筛法求一定范围内素数,但没法进入循环

[复制链接]
发表于 2022-7-22 17:15:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 额外减小 于 2022-7-22 17:35 编辑
  1. #include <stdio.h>

  2. int main()
  3. {
  4.         long n,b,c;
  5.         printf("请输入最大数字:");
  6.         scanf("%ld",&n);
  7.         long a[n+1];
  8.         for(long count=0;count<n;count++)
  9.         {
  10.                 a[count]=count+1;//创建自然数列
  11.         }
  12.         a[n]='\0';
  13.         for(b=2;b<=n/2.0;b++);//b为筛子,筛去的数赋值0.  
  14.         {
  15.                 if(a[b-1])
  16.                 {
  17.                         for(c=2;b*c<=n;c++)//b*c数筛去.
  18.                     {
  19.                                 a[b*c-1]=0;
  20.                         }
  21.                 }
  22.         }
  23.         a[0]=0;
  24.         for(long count_1=0;count_1<n;count_1++)
  25.         {
  26.                 if(a[count_1])
  27.                 printf("  %ld  ",count_1+1);//输出未赋值0的数
  28.         }
  29.         return 0;
  30. }
复制代码


刚学到数组,写了个代码用筛法计算从2到n的素数,但总是把全部的范围内的数都输出,检测了一下发现是for循环嵌套的内层循环没被执行,请各位大佬帮我下,谢谢

  1. 请输入最大数字:10
  2.   2    3    4    5    6    7    8    9    10
  3. --------------------------------
  4. Process exited after 1.648 seconds with return value 0
  5. 请按任意键继续. . .
复制代码


                               
登录/注册后可看大图

上面是运行的例子。
最佳答案
2022-7-22 19:24:23
       第 14 行:
       for(b=2;b<=n/2.0;b++) ; //b为筛子,筛去的数赋值0.
       是不是应该把红色的分号删除掉?  
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-7-22 17:17:31 | 显示全部楼层
我可以理解标准答案,但我自己这种算法一直看不出错在哪?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-7-22 19:24:23 | 显示全部楼层    本楼为最佳答案   
       第 14 行:
       for(b=2;b<=n/2.0;b++) ; //b为筛子,筛去的数赋值0.
       是不是应该把红色的分号删除掉?  
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2022-7-22 21:34:47 | 显示全部楼层
jackz007 发表于 2022-7-22 19:24
第 14 行:
       for(b=2;b

我的天呐,我居然没看出来
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-7-22 21:35:52 | 显示全部楼层
本帖最后由 额外减小 于 2022-7-22 21:37 编辑
jackz007 发表于 2022-7-22 19:24
第 14 行:
       for(b=2;b


谢谢您,已经解决!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-24 01:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表