一位发福利人士 2022-02-06 19:57 采纳率: 94.1%
浏览 41
已结题

这一题很难,很有挑战性,希望你们可以答对

题目描述
小 A 有一个质数口袋,里面可以装各个质数。他从 22 开始,依次判断各个自然数是不是质数,如果是质数就会把这个数字装入口袋。口袋的负载量就是口袋里的所有数字之和。但是口袋的承重量有限,不能装得下总和超过 LL(1 \le L \le {10}^51≤L≤10
5
)的质数。给出 LL,请问口袋里能装下几个质数?将这些质数从小往大输出,然后输出最多能装下的质数个数,所有数字之间有一空行。

输入格式
一行一个正整数 LL。

输出格式
将这些质数从小往大输出,然后输出最多能装下的质数个数,所有数字之间有一空行。

输入输出样例
输入 #1
100
输出 #1
2
3
5
7
11
13
17
19
23
9

  • 写回答

1条回答 默认 最新

  • LYSnowy 2022-02-07 09:58
    关注
    #include <iostream>
    using namespace std;
    
    bool prime(int a) {
        if (a == 0 || a == 1) {
            return false;
        }
        if (a == 2) {
            return true;
        }
        for (int i = 2; i < a; i++) {
            if (a % i == 0) {
                return false;
            }
        }
        return true;
    }
    int main() {
        int n, add = 0, num = 0; //n代表口袋内质数的最大值,add代表当前所有质数的和,num是个数
        cin >> n;
        for (int i = 2;; i++) {
            if (prime(i) == true && add + i <= n) {
                add += i;
                cout << i << endl;
                num++;
            }
            if (add + i > n) { //没有这个判断,无法跳出循环
                break;
            }
        }
        cout << num;
        return 0;
    }
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 2月16日
  • 已采纳回答 2月8日
  • 创建了问题 2月6日

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。