我需要创建一个包含前100个素数的数组,这是我的代码:
var premier= [];
var nombre= premier.length;
function isPrime(n)
{
if(n < 2)
{
return false;
}
for(i=2; i<Math.sqrt(n); i++)
{
if(n%i===0)
{
return false;
}
}
return true
};
while(nombre<100)
{
var j=2
if(isPrime(j)==true)
{
premier.push(j);
}
j=j+1
}
我是Javascript的初学者,但我测试了isPrime
函数,即使对于大数字也能正常工作。
但是当我运行程序时,我有:
致命错误:JS分配失败 - 处理内存不足
我认为这部分是错误的:
while(nombre<100)
{
var j=2
if(isPrime(j)=true)
{
premier.push(j);
}
j=j+1
}
console.log(premier)
但我不知道为什么
答案 0 :(得分:3)
每次循环运行时,您都会重复设置j=2
,并且永远不会更改nombre
,因此循环永远不会结束。请注意,JavaScript按值设置文字值,而不是按引用设置,因此nombre = premier.length
不会神奇地更新。
此外,if( x = true)
形式的语句将设置 x
为true,然后自动传递条件。在这种情况下,由于x
是函数调用,因此语法无效。
你的意思是?
var j = 2;
while(premier.length < 100) {
if( isPrime(j)) premier.push(j);
j++;
}