题目:
求小于等于给定数值的质数之和。
质数是一个大于1的整数,
只有 1 和它本身两个约数的数叫质数。例如,2 是质数,因为它只能被 1 和 2 整除。1 不是质数,因为它只能被自身整除。

给定的数不一定是质数。

要求:

sumPrimes(10) 应该返回一个数字。
sumPrimes(10) 应该返回 17。
sumPrimes(977) 应该返回 73156。

代码:

<script type="text/javascript">
	function sumPrimes(num) {
		var p = [];
		for (var i = 2; i <= num; i++) {
			var flag = true;
			for (var j = 2; j < i; j++) {
				if (i % j === 0) {
					flag = false;
					break;
				} //只有有其他约数就可以跳出循环了
			}
			if (flag) {
				p.push(i);
			}
		}
		return p.reduce(function(sum, cur) {
			return sum + cur;
		});
	}
	sumPrimes(977);
</script>

 

不过求质数之和其实有方法上的简化,一个数若可以进行因数分解,那么分解时得到的两个数一定是一个小于等于sqrt(n),一个大于等于sqrt(n),据此,上述代码中并不需要遍历到n-1,遍历到sqrt(n)即可,因为若sqrt(n)左侧找不到约数,那么右侧也一定找不到约数

作者:zooeydotmango
链接:https://www.jianshu.com/p/66220cb7977d