[英]I don't get squaring loop index in prime number function
下面是我的函數,它總結了低於給定maxNum
所有素數。
我不明白為什么當使用j <= num
而不是j ** 2 <= num
時, isPrime
函數中的 for 循環不起作用。
function sumPrimes(maxNum) { let sum = 0; for (let i = 2; i <= maxNum; i++) { if (isPrime(i)) { sum += i } } return sum } function isPrime(num) { for (let j = 2; j <= num; j++) { // when I use j ** 2 <= num it works if (num % j === 0) { return false } } return true } console.log(sumPrimes(20))
如果您使用j <= num
,循環會將j
計數到數字本身,然后它將匹配num % j === 0
並返回 false。
因此,如果num
為 17,則循環將執行17 <= 17
並且循環體執行17 % 17 === 0
所以它總是返回 false,無論你傳入什么數字。
您可以在循環頭中使用j < num
而不是j <= num
,這也應該有效,因為使用小於號時永遠不會達到數字本身。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.