题解 | #查找组成一个偶数最接近的两个素数#

查找组成一个偶数最接近的两个素数

http://www.nowcoder.com/practice/f8538f9ae3f1484fb137789dec6eedb9

#include <stdio.h>
#include <math.h>
int is_prim(int a) {
    int prim = 1;
    int x = sqrt(a) + 1;
    for (int i = 2; i < x; i++) {
        if (a % i == 0) {//判断是否是素数
            prim = 0;
            break;
        }
    }
    return prim;
}
int main(void) {
    int number;
    while (scanf("%d", &number) != EOF) {
        int start = number / 2;
        for (int i = start; i >= 2; i--) {
            if (is_prim(i) && is_prim(number - i)) {//寻找最近的两个素数
                printf("%d\n%d\n", i, number - i);
                break;
            }
        }
    }
    return 0;
}

全部评论

相关推荐

评论
点赞
收藏
分享
牛客网
牛客企业服务