鱼C论坛

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

[已解决]C语言15讲,求10000以内的素数

[复制链接]
发表于 2020-6-20 11:54:32 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 猪猪虾 于 2020-6-20 11:55 编辑

我的结果比答案少2个。。。答案是1229

  1. #include <stdio.h>

  2. // 求 10000 以内的素数个数
  3. int main()
  4. {
  5.         int i,num = 1,total_su_num = 0;
  6.         do
  7.         {
  8.                 num++;
  9.                 //一个一个的进行判断
  10.             for(i=2;i<=(num/2);i++)
  11.             {
  12.                     if ((num % i) == 0)
  13.                     {
  14.                             break;
  15.                 }       
  16.                 else if (i == (num/2))  //判断是否循环一直进行到底,若到底了,说明中途没有Break
  17.                 {
  18.                         total_su_num += 1;       
  19.                 }
  20.                           
  21.             }               
  22.         }while(num <= 10000);
  23.         printf("10000以内共有%d个素数!",total_su_num);
  24.     return 0;
  25. }
复制代码
最佳答案
2020-6-20 12:30:49
猪猪虾 发表于 2020-6-20 12:18
我的为啥少2个数啊

自己打印一下就能看出来了。
当 num = 2 或 num = 3 时,循环根本不会执行,所以他们被判定为非质数了。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-6-20 12:15:12 | 显示全部楼层
本帖最后由 永恒的蓝色梦想 于 2020-6-20 12:16 编辑
  1. #include<stdio.h>
  2. #define MAX 10000
  3. unsigned short result = 1, i, j, k;
  4. bool primes[MAX];


  5. int main() {
  6.     for (i = 3; i < MAX; i += 2) {
  7.         if (!primes[i]) {
  8.             ++result;
  9.             k = i << 1;

  10.             for (j = i + k; j < MAX; j += k) {
  11.                 primes[j] = true;
  12.             }
  13.         }
  14.     }

  15.     printf("%u", result);
  16.     return 0;
  17. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-6-20 12:18:04 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-20 12:27:18 | 显示全部楼层

unsigned short..
不走正道
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-20 12:30:49 | 显示全部楼层    本楼为最佳答案   
猪猪虾 发表于 2020-6-20 12:18
我的为啥少2个数啊

自己打印一下就能看出来了。
当 num = 2 或 num = 3 时,循环根本不会执行,所以他们被判定为非质数了。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-20 12:31:27 | 显示全部楼层
qiuyouzhi 发表于 2020-6-20 12:27
unsigned short..
不走正道

我的个人习惯,能省则省有什么问题吗
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-8-6 02:12

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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