经典算法详解(3)将大于2的偶数分解成两个素数之和

简介: 1 #include 2 3 using namespace std; 4 5 bool isPrime(int n) { 6 for (int i = 2; i < n; i++) { 7 if (n%i == 0) { //能被2到把自身小1的数...
 1 #include<iostream>
 2 
 3 using namespace std;
 4 
 5 bool isPrime(int n) {
 6     for (int i = 2; i < n; i++) {
 7         if (n%i == 0) {    //能被2到把自身小1的数整除的都不是素数
 8             return false;
 9         }
10     }
11     return true;
12 }
13 
14 int  getPrimePair(int n) {
15     if ((n %2== 0) && (n < 2)) {    //不符合题目输入要求返回0,表示失败
16         return 0;
17     }
18     for (int i = 2; i < n / 2; i++) {
19         if (isPrime(i) && isPrime(n - i)) {
20             cout << n << " = " << i << " + " << n - i << endl;
21         }
22     }
23     return 1;    //返回1表示成功
24 }
25 
26 int main(int argc, char *argv[]) {
27     getPrimePair(28);
28     getchar();
29     return 0;
30 }

思路:将n分为i和n-i,编写判断素数函数,看i和n-i是否都是素数,是的话打印出来。

相关文章
|
7月前
|
并行计算 算法 计算机视觉
【MATLAB 】 EMD信号分解+模糊熵(近似熵)算法
【MATLAB 】 EMD信号分解+模糊熵(近似熵)算法
118 0
|
7月前
|
并行计算 算法 计算机视觉
【MATLAB 】 EEMD 信号分解+模糊熵(近似熵)算法
【MATLAB 】 EEMD 信号分解+模糊熵(近似熵)算法
237 0
|
7月前
|
并行计算 算法 计算机视觉
【MATLAB 】 CEEMD 信号分解+模糊熵(近似熵)算法
【MATLAB 】 CEEMD 信号分解+模糊熵(近似熵)算法
211 0
|
7月前
|
并行计算 算法 计算机视觉
【MATLAB 】 CEEMDAN 信号分解+模糊熵(近似熵)算法
【MATLAB 】 CEEMDAN 信号分解+模糊熵(近似熵)算法
381 0
|
7月前
|
算法 计算机视觉
【MATLAB 】 EMD信号分解+希尔伯特黄变换+边际谱算法
【MATLAB 】 EMD信号分解+希尔伯特黄变换+边际谱算法
214 0
|
7月前
|
算法 计算机视觉
【MATLAB 】 EEMD 信号分解+希尔伯特黄变换+边际谱算法
【MATLAB 】 EEMD 信号分解+希尔伯特黄变换+边际谱算法
735 0
|
1月前
|
算法 Python
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果;贪心算法在每一步选择局部最优解,追求全局最优;动态规划通过保存子问题的解,避免重复计算,确保全局最优。这三种算法各具特色,适用于不同类型的问题,合理选择能显著提升编程效率。
53 2
|
2月前
|
机器学习/深度学习 算法 搜索推荐
django调用矩阵分解推荐算法模型做推荐系统
django调用矩阵分解推荐算法模型做推荐系统
45 4
|
5月前
|
并行计算 算法 Python
Dantzig-Wolfe分解算法解释与Python代码示例
Dantzig-Wolfe分解算法解释与Python代码示例
|
4月前
|
存储 算法 Java
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
48 0