鱼C论坛

 找回密码
 立即注册
查看: 813|回复: 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;

}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-10-24 17:40:25 | 显示全部楼层
#include<stdio.h>
int main()
{
        int i,j,k=0;//i是2-10000待确认是否为素数的数,j表示i的因子,k表示素数的个数
        for(i=2;i<10000;i++)
        {
                for(j=2;j*j<=i;j++)
                {
                        if(i%j==0)//判断i是否能被1和本身以外的数整除,%表示求余
                        break;//break跳出第二个for循环
                }
                if(j*j>i)
                {
                        printf("%d ",i);
                        k++;//每增加一个素数k就加1
                        if(k%10==0)//一行打印10个数之后换行
                        {
                                printf("\n");
                        }
                }
        }
}
想知道小甲鱼最近在做啥?请访问 -> 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;

}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

依你的程序修改
#include<stdio.h>
int main()
{
        int i,j,count=0;  // i 是2-10000待确认是否为素数的数,j表示i的因子,count表示素数的个数
        for(i=2;i<10000;i++)
        {
                for(j=2;j*j<=i;j++)
                {
                        if(i%j==0)  // 判断i是否能被1和本身以外的数整除,%表示求余
                        break;  // break跳出第二个for循环
                }
                if(j*j>i)
                {
                        count++;  // 每增加一个素数count就加1
                }
        }
        printf("\n");
        printf("10000以内共有%d个素数!",count);
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

i % j == 0
这个判断得到的不是 “不是素数” 的个数吗?为什么count还要++呢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

楼主的count表示的是“不是素数”,最后用10000-count来得到素数个数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-12 20:47

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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