博客
关于我
习题5-4 使用函数求素数和 (20 分)
阅读量:217 次
发布时间:2019-02-28

本文共 1636 字,大约阅读时间需要 5 分钟。

判断素数的函数prime(p)和计算区间内素数和的函数PrimeSum(m, n)。素数即只能被1和自身整除的数。prime函数返回1当且仅当p为素数,否则返回0。PrimeSum函数返回区间内所有素数的和。

    素数判断与求和    

实现素数判断与求和的两个函数

函数定义

int prime(int p);

int PrimeSum(int m, int n);

prime函数:当输入p为素数时返回1,否则返回0。

PrimeSum函数:计算区间[m, n]内所有素数的和。

素数的定义

素数是指大于1的自然数,除了1和自身外,不能被其他自然数整除。

例如:2、3、5、7等等。注意:1不是素数,2是最小的素数。

实现思路

1. prime函数的实现逻辑:

- 当p小于2时,返回0。
- 当p等于2时,返回1。
- 对于大于2的数,检查是否能被2或其他奇数整除。
- 优化:跳过偶数,直接处理奇数,提高效率。 2. PrimeSum函数的实现逻辑:
- 遍历区间[m, n]中的每个数。
- 使用prime函数判断是否为素数。
- 累加所有素数的值,返回总和。

代码实现

            int prime(int p) {                if (p < 2) return 0;                if (p == 2) return 1;                if (p % 2 == 0) return 0;                for (int i = 3; i * i <= p; i += 2) {                    if (p % i == 0) return 0;                }                return 1;            }                        int PrimeSum(int m, int n) {                int sum = 0;                for (int p = m; p <= n; p++) {                    if (prime(p)) {                        sum += p;                    }                }                return sum;            }        

测试样例

输入:-1 10

输出:Sum of (2 3 5 7) = 17

另一个测试用例:输入2 2,输出2;输入3 5,输出8。

这个实现通过模拟人类思维过程,提供了一个清晰且易于理解的解决方案。函数prime通过检查2和奇数来判断素数,而PrimeSum函数则利用prime函数逐个检查区间内的每个数,累加素数的和。这种方法既简洁明了,又能高效地解决问题。

转载地址:http://bnii.baihongyu.com/

你可能感兴趣的文章
Objective-C内存管理教程和原理剖析(三)
查看>>
Objective-C实现 Greedy Best First Search最佳优先搜索算法(附完整源码)
查看>>
Objective-C实现 jugglerSequence杂耍者序列算法 (附完整源码)
查看>>
Objective-C实现 lattice path格子路径算法(附完整源码)
查看>>
Objective-C实现1000 位斐波那契数算法(附完整源码)
查看>>
Objective-C实现2 个数字之间的算术几何平均值算法(附完整源码)
查看>>
Objective-C实现2d 表面渲染 3d 点算法(附完整源码)
查看>>
Objective-C实现2D变换算法(附完整源码)
查看>>
Objective-C实现3n+1猜想(附完整源码)
查看>>
Objective-C实现3n+1猜想(附完整源码)
查看>>
Objective-C实现9x9乘法表算法(附完整源码)
查看>>
Objective-C实现9×9二维数组数独算法(附完整源码)
查看>>
Objective-C实现A*(A-Star)算法(附完整源码)
查看>>
Objective-C实现A-Star算法(附完整源码)
查看>>
Objective-C实现abbreviation缩写算法(附完整源码)
查看>>
Objective-C实现ABC人工蜂群算法(附完整源码)
查看>>
Objective-C实现activity selection活动选择问题算法(附完整源码)
查看>>
Objective-C实现AC算法(Aho-Corasick) 算法(附完整源码)
查看>>
Objective-C实现adaboost算法(附完整源码)
查看>>
Objective-C实现Adler32算法(附完整源码)
查看>>