Betty_mere 2022-02-12 21:57 采纳率: 100%
浏览 108
已结题

输入一个不小于6的正整数n,将其拆分成三个素数之和,输出任意一解即可。

#问题:
OJ上面时间超限,1804ms,本人大一cai狗,完全不知算法该如何优化了
#思路:
1.打好素数表
2.循环求拆分的三个素数
题目如下:

img


源代码如下:

#include <iostream>
#include <cmath>
#include <vector>
using namespace std;
vector<int>prime;
bool isPrime(int a)//进来的都是奇数
{
        int sq = sqrt(a);
        bool flag = true;
        for (int i = 3; i <= sq && flag; i += 2)
            if (a % i == 0)
                flag = false;
        return flag;
}
void f()
{
    prime.push_back(2);
    for (int i = 3; prime.back() <= 19999; i+=2)
    {
        if (isPrime(i))
            prime.push_back(i);
    }
}
int main()
{
    f();
    int a, i, j, k;
    while (cin >> a)
    {
        for (i = 0; i < prime.size() ; i++)
            for (j = 0; prime[j] < a-3 ; j++)
                for (k = 0; prime[k] < a-3; k++)
                {
                    if (prime[i] + prime[j] + prime[k] == a)
                    {
                        cout << prime[i] << " " << prime[j] << " " << prime[k] << endl;
                        goto aa;
                    }
                }
    aa:;
    }
    return 0;
}

恳求各路老爷们看看我吧!
感激万分!

  • 写回答

1条回答 默认 最新

  • Nikel_Chieh 2022-02-12 22:06
    关注

    不要搞第三个for循环了,第三个数就是a - prime[i] - prime[j]
    再判断一下第三个数是不是素数就可以了

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

报告相同问题?

问题事件

  • 系统已结题 2月21日
  • 已采纳回答 2月13日
  • 修改了问题 2月13日
  • 创建了问题 2月12日

悬赏问题

  • ¥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测量血氧,找不到相关的代码。