宝塔服务器面板,一键全能部署及管理,送你10850元礼包,点我领取

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

给定的数不一定是质数。

要求:

sumPrimes10) 应该返回一个数字。
sumPrimes10) 应该返回 17。
sumPrimes977) 应该返回 73156。

代码:

<script type="text/javascript">
	function sumPrimesnum) {
		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.pushi);
			}
		}
		return p.reducefunctionsum, cur) {
			return sum + cur;
		});
	}
	sumPrimes977);
</script>

 

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

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