鱼C论坛

 找回密码
 立即注册
查看: 1554|回复: 6

[已解决]素数

[复制链接]
发表于 2020-12-31 11:27:07 | 显示全部楼层 |阅读模式

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

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

x
输入二个整数a和b(2 <= a <b <1000),输出a和b之间的素数。

注意:必须使用复制筛选法。

输入
有多组数据,每组包括两个整数a和b。
输出
a和b之间的素数,每组输出一行,两个素数之间用1个空格分开,末尾不能有空格。
最佳答案
2021-1-1 13:35:10
原来打算从今天起,不再回答问题了,但还是凑够技术值 500 吧,还差 16 个,做个完美
  1. #include<stdio.h>
  2. #include<math.h>
  3. int main()
  4. {
  5.         int a, b, k = 0, n = 0, arr[300], i, j;
  6.         scanf("%d%d", &a, &b);
  7.        
  8.         for (i = 0; i <= b; i++)
  9.         {
  10.                 if (a <= b)
  11.                 {
  12.                         arr[i] = a;   //为数组赋初值
  13.                         a++;
  14.                         k++;
  15.                 }
  16.         }

  17.         for (i = 2; i < sqrt(b); i++)  //如果需要找a-b范围内的素数,只须进行到除数为根号下n(取整数就可)
  18.         {
  19.                 for (j = 0; j <= k; j++)
  20.                         if (arr[j] != 0)
  21.                                 if (arr[j] % i == 0)
  22.                                 {
  23.                                         arr[j] = 0;
  24.                                 }

  25.         }

  26.         printf("\n");

  27.         for (i = 0; i <= k; i++)
  28.         {
  29.                 if (arr[i] != 0)
  30.                 {
  31.                         printf("%3d ", arr[i]);
  32.                         n++;
  33.                 }

  34.                 if (n == 10)    // 满10个换行
  35.                 {
  36.                         printf("\n");
  37.                         n = 0;     // 一次完成之后初始化
  38.                 }
  39.         }
  40.         printf("\b");   // 删除最后那个素数后面的空格
  41.         printf("\n");

  42.         return 0;
  43. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-12-31 12:57:40 | 显示全部楼层
      楼主,解释一下,什么叫 "复制筛选法"?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-1 13:35:10 | 显示全部楼层    本楼为最佳答案   
原来打算从今天起,不再回答问题了,但还是凑够技术值 500 吧,还差 16 个,做个完美
  1. #include<stdio.h>
  2. #include<math.h>
  3. int main()
  4. {
  5.         int a, b, k = 0, n = 0, arr[300], i, j;
  6.         scanf("%d%d", &a, &b);
  7.        
  8.         for (i = 0; i <= b; i++)
  9.         {
  10.                 if (a <= b)
  11.                 {
  12.                         arr[i] = a;   //为数组赋初值
  13.                         a++;
  14.                         k++;
  15.                 }
  16.         }

  17.         for (i = 2; i < sqrt(b); i++)  //如果需要找a-b范围内的素数,只须进行到除数为根号下n(取整数就可)
  18.         {
  19.                 for (j = 0; j <= k; j++)
  20.                         if (arr[j] != 0)
  21.                                 if (arr[j] % i == 0)
  22.                                 {
  23.                                         arr[j] = 0;
  24.                                 }

  25.         }

  26.         printf("\n");

  27.         for (i = 0; i <= k; i++)
  28.         {
  29.                 if (arr[i] != 0)
  30.                 {
  31.                         printf("%3d ", arr[i]);
  32.                         n++;
  33.                 }

  34.                 if (n == 10)    // 满10个换行
  35.                 {
  36.                         printf("\n");
  37.                         n = 0;     // 一次完成之后初始化
  38.                 }
  39.         }
  40.         printf("\b");   // 删除最后那个素数后面的空格
  41.         printf("\n");

  42.         return 0;
  43. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2021-1-1 16:15:49 | 显示全部楼层
风过无痕1989 发表于 2021-1-1 13:35
原来打算从今天起,不再回答问题了,但还是凑够技术值 500 吧,还差 16 个,做个完美

大佬能不能回答下我的问题...谢谢
https://fishc.com.cn/thread-187884-1-1.html
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-1 19:06:24 | 显示全部楼层
风过无痕1989 发表于 2021-1-1 13:35
原来打算从今天起,不再回答问题了,但还是凑够技术值 500 吧,还差 16 个,做个完美

八点半到九点,我发五个题目上来,帮助你完成目标
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-1 20:29:59 | 显示全部楼层
乐乐学编程 发表于 2021-1-1 19:06
八点半到九点,我发五个题目上来,帮助你完成目标

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

使用道具 举报

发表于 2021-1-3 08:58:00 | 显示全部楼层
LZ问题解决了吗
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-3 16:11

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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