鱼C论坛

 找回密码
 立即注册
查看: 1013|回复: 5

[已解决]统计10000以内的素数的个数

[复制链接]
发表于 2020-10-24 17:20:10 | 显示全部楼层 |阅读模式

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

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

x
#include<stdio.h>
int main()
{
    int i,j,count=2;
    for(i=5;i<=10000;i++)
    {
        for(j=2;j<=i/2;j++)
        {
            if(i%j==0)
                break;
        }
        count++;

    }
    printf("10000以内共有%d个素数!",10000-count);
    return 0;

}

运行结果一直是2,求大神解答
(正确答案是1229)
最佳答案
2020-10-24 17:43:07
count++放if里面
#include<stdio.h>
int main()
{
    int i,j,count=2;
    for(i=5;i<=10000;i++)
    {
        for(j=2;j<=i/2;j++)
        {
            if(i%j==0)
                        {
                                count++;
                                break;
                        }
        }
    }
    printf("10000以内共有%d个素数!",10000-count);
    return 0;

}
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-10-24 17:40:25 | 显示全部楼层
  1. #include<stdio.h>
  2. int main()
  3. {
  4.         int i,j,k=0;//i是2-10000待确认是否为素数的数,j表示i的因子,k表示素数的个数
  5.         for(i=2;i<10000;i++)
  6.         {
  7.                 for(j=2;j*j<=i;j++)
  8.                 {
  9.                         if(i%j==0)//判断i是否能被1和本身以外的数整除,%表示求余
  10.                         break;//break跳出第二个for循环
  11.                 }
  12.                 if(j*j>i)
  13.                 {
  14.                         printf("%d ",i);
  15.                         k++;//每增加一个素数k就加1
  16.                         if(k%10==0)//一行打印10个数之后换行
  17.                         {
  18.                                 printf("\n");
  19.                         }
  20.                 }
  21.         }
  22. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-24 17:43:07 | 显示全部楼层    本楼为最佳答案   
count++放if里面
#include<stdio.h>
int main()
{
    int i,j,count=2;
    for(i=5;i<=10000;i++)
    {
        for(j=2;j<=i/2;j++)
        {
            if(i%j==0)
                        {
                                count++;
                                break;
                        }
        }
    }
    printf("10000以内共有%d个素数!",10000-count);
    return 0;

}
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-24 17:47:21 | 显示全部楼层
本帖最后由 风过无痕1989 于 2020-10-24 17:48 编辑

依你的程序修改

  1. #include<stdio.h>
  2. int main()
  3. {
  4.         int i,j,count=0;  // i 是2-10000待确认是否为素数的数,j表示i的因子,count表示素数的个数
  5.         for(i=2;i<10000;i++)
  6.         {
  7.                 for(j=2;j*j<=i;j++)
  8.                 {
  9.                         if(i%j==0)  // 判断i是否能被1和本身以外的数整除,%表示求余
  10.                         break;  // break跳出第二个for循环
  11.                 }
  12.                 if(j*j>i)
  13.                 {
  14.                         count++;  // 每增加一个素数count就加1
  15.                 }
  16.         }
  17.         printf("\n");
  18.         printf("10000以内共有%d个素数!",count);
  19. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-24 18:19:53 | 显示全部楼层
冰雪世界 发表于 2020-10-24 17:43
count++放if里面
#include
int main()

i % j == 0
这个判断得到的不是 “不是素数” 的个数吗?为什么count还要++呢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-24 18:24:09 | 显示全部楼层
大神本人 发表于 2020-10-24 18:19
i % j == 0
这个判断得到的不是 “不是素数” 的个数吗?为什么count还要++呢

楼主的count表示的是“不是素数”,最后用10000-count来得到素数个数
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-15 06:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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