鱼C论坛

 找回密码
 立即注册
查看: 1424|回复: 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 个,做个完美
#include<stdio.h>
#include<math.h>
int main()
{
        int a, b, k = 0, n = 0, arr[300], i, j;
        scanf("%d%d", &a, &b);
        
        for (i = 0; i <= b; i++)
        {
                if (a <= b)
                {
                        arr[i] = a;   //为数组赋初值
                        a++;
                        k++;
                }
        }

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

        }

        printf("\n");

        for (i = 0; i <= k; i++)
        {
                if (arr[i] != 0)
                {
                        printf("%3d ", arr[i]);
                        n++;
                }

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

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

使用道具 举报

发表于 2020-12-31 12:57:40 | 显示全部楼层
      楼主,解释一下,什么叫 "复制筛选法"?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

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

        }

        printf("\n");

        for (i = 0; i <= k; i++)
        {
                if (arr[i] != 0)
                {
                        printf("%3d ", arr[i]);
                        n++;
                }

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

        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> 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
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

八点半到九点,我发五个题目上来,帮助你完成目标
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

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

使用道具 举报

发表于 2021-1-3 08:58:00 | 显示全部楼层
LZ问题解决了吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-12 06:46

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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