题解 | #World Fragments I#

Until the Blue Moon Rises

https://ac.nowcoder.com/acm/contest/57357/H

H题题解

需要知道的知识:哥德巴赫猜想

哥德巴赫猜想的现代陈述为:任一大于5的整数都可写成三个质数之和。

由此可以得到两种情况:

1.强哥德巴赫猜想(强哥猜):即任一大于2的偶数都可写成两个质数之和;(未被证明,但是同时也没有被推翻,即在本体的范围内强哥猜成立)

2.弱哥德巴赫猜想(弱哥猜):任何一个大于5的奇数都能被表示成三个奇质数的和。(一个质数可以被多次使用);(已经被证明) 所以本题有三种情况:

1.n=1时,即A为质数时成立

2.n=2时,可以分为两种情况:1.和为偶数时,使用强哥猜。2.和为奇数时,当且仅当和-2为质数时成立,因为奇数只能由一个奇数和一个偶数相加得到,而除了二以外的偶数都不是质数,所以只能是2+a,也就是a为质数时才成立,所以减去2:

3.n>2时。此时就可以运用哥德巴赫猜想了,n=3时,只要和大于5,也就是和为6(2+2+2)时是最小的成立条件。以此类推,只要满足和大于等于2*n即可。

代码如下:

#include<bits/stdc++.h>
typedef long long ll;
int su(ll x){//判断素数
    if(x==1) return 0;
    for(int i=2;i<=sqrt(x);i++){
        if(x%i==0) return 0;
    }
    return 1;
}
ll a[1010];
int main(){
    ll n,he=0;bool b;
    std::cin>>n;
    for(int i=1;i<=n;i++){
        std::cin>>a[i];
        he+=a[i];
    }
    if(n==1){
        if(su(he)) b=1;
        else b=0;
    }
    else if(n==2){//哥德巴赫猜想的部分
        if(he%2==0){//强哥猜
            if(he>=4) b=1;
            else b=0;
        }
        else{//弱哥猜
            if(he>=5&&su(he-2)) b=1;
            else b=0;
        }
    }
    else{
        if(he>=2*n) b=1;//此时最小就是每个数字都为2时
        else b=0;
    }
    if(b) std::cout<<"Yes";
    else std::cout<<"No";
    return 0;
}
全部评论
用he 作为变量名 易懂 但是建议使用sum
点赞 回复 分享
发布于 2023-07-25 15:21 河南

相关推荐

09-26 19:45
门头沟学院 Java
点赞 评论 收藏
分享
头像
10-22 20:13
中南大学 Java
序言大家好呀。我是希晨er,一个初入职场的程序猿小登最近上班摸鱼刷到了一篇文章:10年深漂,放弃高薪,回长沙一年有感,还有聊聊30岁大龄程序员过往的心路历程,突然就有点感慨。我如今也做出了和大明哥一样的抉择,只是更早。此外我22年的人生,好像从来没好好记录过。正好现在工作不太忙,就想把这些经历写下来,也希望能得到社区里各位前辈的指点个人背景我是03年出生的西安娃,父母都是普通打工人。刚从中南大学软件工程专业毕业半年,现在在老家的央企过着躺平摆烂的日子成长轨迹从农村到城市的童年我家并不是西安的,只是爸妈在西安上班,从小学之后就把我接到了西安。后来老家房子拆了,爷爷奶奶也搬了过来。农村的生活,我觉...
Yki_:看哭了,恋爱那一段你女朋友说你不够关心她,可你毕竟也愿意遇到矛盾写几千字来和她慢慢分析;说不愿意给她花钱,我感觉可能只是消费观不一样;如果她想留在长沙,也应该提前跟你说开。不过她也许会心疼你放弃大厂offer转向数字马力?我也因为同样的原因有过一段幸福而充满遗憾的感情,不过跟爱情相比确实前途更重要一点。至于offer的选择,换我我也会这么选。把这些旧事记录下来以后,接下来就好好向前看吧,加油兄弟
🍊晨光随笔
点赞 评论 收藏
分享
评论
19
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务