Lmj212 2023-01-30 22:26 采纳率: 100%
浏览 44
已结题

对任一个大于4的偶数,都可以分解为两个素数之和。从文件中读入两个数m、n,编程验证。


#include<bits/stdc++.h>
using namespace std;

int cnt = 0;

bool isprime(int n)
{
    if(n == 0 || n == 1) return false;
    for(int i = 2; i <= sqrt(n); i++)
        if(n % i == 0) return false;
    return true;
}

void goldbach(int n)
{
    for(int i = 2; i <= n / 2; i++)
        if(isprime(i) && isprime(n - i))
        {
            printf("%d+%d=%d\n", i, n - i, n);
            cnt++;
        }
}

int main()
{
    int n, m;
    scanf("%d%d", &n, &m);
    for(int i = n; i <= m; i += 2) goldbach(i);
    end = clock();
    printf("%d", cnt);
    return 0;
}

怎么办90分代码,TLE,还能怎么优化(咬牙切齿

  • 写回答

3条回答 默认 最新

  • 我是刘昱程 2023-01-30 22:36
    关注

    制作不易,请采纳 : 我试过了是对的

    
    #include <stdio.h>
    int  isPrime(int n)
    {
        int i;
        if (n <= 3)  return n > 1;
        for (i = 2; i * i <= n; i++)
            if (n % i == 0) return 0;
        return 1;
    }
    int main()
    {
        int i, n;
        while (scanf("%d", &n) == 1 && n > 0) // 输入 <= 0  结束
        {
            if (n % 2 != 0) continue;  //输入非偶数,重新输入
            for (i = n / 2; i > 1; i--) {
                if (isPrime(i) && isPrime(n - i))
                {
                    printf("%-d=%-d+%-d\n", n, i, n - i);//输出
                    break;
                }
            }
        }
        return 0;
    }
     
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 2月2日
  • 已采纳回答 1月31日
  • 创建了问题 1月30日

悬赏问题

  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测