分解质因数算法

分解质因数算法 
1.从N開始递减。找到满足 : n%i ==0 && n是素数 -> result
2.存result到数组,递归运行(n/result)




var result = new Array();


var factor = function f(n){
if(n == 1){return ;}


var n1 = n;
while(n1>1){
if(isPrime(n1) && n % n1 == 0) {break;}
n1--;
}


if(n1 == 1){return ;}


result.push(n1);


f(n / n1);


}


var isPrime = function (n){
for(var i = 2; i < n ; i++){if(n%i == 0){return false;}}


return true;
}


factor(45);
console.log(result);


posted on 2017-04-18 17:38  wgwyanfs  阅读(210)  评论(0编辑  收藏  举报

导航