这里的代码检查从 2 到 n 的素数:
<script>
function showPrimes(n) {
for (let i = 2; i < n; i++) {
if (!isPrime(i)) continue;
alert(i); // a prime
}
}
function isPrime(n) {
for (let i = 2; i < n; i++) {
if ( n % i == 0) return false;
}
return true;
}
</script>
但是我不明白为什么它适用于数字 2 并在 n 和 i 都等于 2 时返回 false 而其他素数不会发生这种情况。我是 javascript(和一般编程)的新手,根据我的理解,这段代码从第一个循环中的第一次迭代中获取 i(在“showPrimes”函数上)并将其作为参数放在“isPrime”函数上,并在该函数成为“if”条件中的“n”,并检查当它从“isPrime”循环中除以 i 时是否存在余数,因此 (n % i == 0) 应该是 (2 % 2 == 0) 在第一次迭代中,是吗?如果是这样,为什么它像其他质数一样工作,这些质数显然变成假的,不像 (2 % 2 == 0) 这是真的......
我在这里缺少什么?对不起,如果这是一个明显/愚蠢的问题,这是我第一次学习与编程相关的任何东西。
小唯快跑啊
相关分类