栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

XDOJ-歌德巴赫猜想-35

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

XDOJ-歌德巴赫猜想-35

来源:

西安电子科技大学XDOJ在线C语言编程练习题35

问题描述:

德巴赫猜想:
任意一个大偶数都能分解为两个素数的和,
对与输入的一个正偶数,写一个程序来验证歌德巴赫猜想。
由于每个正偶数可能分解成多组素数和,仅输出分解值分别是最小和最大素数的一组,按从小到大顺序输出。

输入输出说明:

输入说明    
输入一个正偶数n,1

输出说明    
输出分解出的两个最小和最大素数。

解题思路:

1.定义一个函数用于判断一个数是不是素数;

2.输入一个数n;

3.循环,当i和n-i都是素数时终止循环并输出;

代码实现:
#include
int prime(int i){
    int j,ret=0;
    if(i!=2){
        for ( j = 2; j < i; j++)
        {
            if (i%j==0)
            {
                ret=1;
            }
        }
    }
    return ret;
}

int main(){
    int n,i,pi,t;
    scanf("%d",&n);
    for ( i = 2; i < n; i++)
    {
        if (prime(i)==0&&prime(n-i)==0)
        {
            printf("%d %d",i,n-i);
            break;
        }
    }
    return 0;
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/587893.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号