C语言验证哥德巴赫猜想

哥德巴赫猜想

众所周知,哥德巴赫猜想是指:

一个不小于6的偶数可以表示为两个奇素数之和。

本程序要实现的功能是对于输入的偶数n,输出所有可能的分解为两个奇素数的结果(按第一个奇素数从小到大的顺序输出)。

完整代码

本程序完整代码如下:

c 复制代码
#include <stdio.h>
#include <math.h>

int prime(unsigned int num) {
	for (unsigned int i = 2; i <= sqrt(num); i++) {
		if (prime(i) && num % i == 0) {
			return 0;
		}
	}
	return 1;
}

int main() {
	unsigned int n, k;
	
	scanf("%d", &n);
	
	for (unsigned int j = 3; j <= n / 2; j += 2) {
		k = n - j;
		if (prime(j) && prime(k)) {
			printf("%d=%d+%d\n", n, j, k);
		}
	}
	
	return 0;
}

代码解释

prime函数

c 复制代码
int prime(unsigned int num) {
	for (unsigned int i = 2; i <= sqrt(num); i++) {
		if (prime(i) && num % i == 0) {
			return 0;
		}
	}
	return 1;
}

prime函数的作用是判断正整数num是否为素数。判断素数的方法是遍历从2到√n之间的所有素数,若均不是num的素因数,则num是素数,否则不是素数。若num有大于√n的素因数k,则必有素因数num/k<√n,因此只需遍历2到√n即可。这里,用到了一次函数迭代。

主函数

c 复制代码
int main() {
	unsigned int n, k;
	
	scanf("%d", &n);
	
	for (unsigned int j = 3; j <= n / 2; j += 2) {
		k = n - j;
		if (prime(j) && prime(k)) {
			printf("%d=%d+%d\n", n, j, k);
		}
	}
	
	return 0;
}

首先用户输入正整数n,再对从3(正数范围内最小的奇素数)到n/2范围内的所有奇数讨论是否满足题意,若满足,直接打印。

运行结果示例

以200为例:

相关推荐
codingPower21 小时前
JAVA后端安全进阶:基于HMAC-SHA256+Nonce+Timestamp的API防重放攻击方案
java·开发语言·spring boot·安全
暗冰ཏོ21 小时前
Go 语言从入门到后端项目实战完整指南
开发语言·后端·golang·go·go语言
Xin_ye1008621 小时前
C# 零基础到精通教程 - 第十七章:前端集成——Blazor 基础
开发语言·c#
LDR00621 小时前
LDR6020:多 Type‑C 端口角色管理与外设上电顺序的智慧核心
c语言·开发语言·云计算
变量未定义~21 小时前
既约分数、阶乘约数、逆元、最大质因子个数【算法赛】
算法
小杍随笔21 小时前
【Rust 工具链管理完全指南:rustup toolchain 命令实战详解】
开发语言·后端·rust
五月君_1 天前
放弃 Python,Kimi 用 TS + Node.js 重写了一个 Kimi Code
开发语言·python·node.js
不羁的木木1 天前
ArkWeb实战学习笔记04-JavaScript与Native通信
笔记·学习·harmonyos
Cloud_Shy6181 天前
解读《Effective Python 3rd Edition》:从练气到老魔
开发语言·python
KaMeidebaby1 天前
卡梅德生物技术快报|Western Blot 实验应用:肺肠轴机制研究全流程技术解析
前端·数据库·人工智能·算法·百度