7-6 验证“哥德巴赫猜想”(20 分)

#一、题目
这里写图片描述

#二、个人理解
此题本质上就是考素数判断。

思想很简单,但是最大数会运行超时。这里介绍一种简单的素数,即只对奇数进行判断,并对数进行一次开方。

在此我希望大家即使不掌握高深的素数判断算法,也应该掌握这个简单又实用的算法。


C语言:

#include <stdio.h>

int is_prime(int n)
{
	if (n < 2) {
		return 0;
	}
	if (n == 2 ) {
		return 1;
	}
	if (n % 2 == 0) {
		return 0;
	}
	for (int i = 3; i * i <= n; i += 2) {
		if (n % i == 0) {
			return 0;
		}
	}
	return 1;

}

int main()
{
	int n;
	scanf("%d", &n);
	for (int i = 2; i < n ; i ++) {
		if (is_prime(i)  && is_prime(n - i)) {
			printf("%d = %d + %d", n, i, n - i);
			break;
		}
}
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值