js实现将一个正整数分解质因数

摘要:js 把一个正整数分解成若干个质数因子的过程称为分解质因数,在计算机方面,我们可以用一个哈希表来存储这个结果。首先,你需要一个判断是否为质数的方法,然后,利用短除法来分解。

js 把一个正整数分解成若干个质数因子的过程称为分解质因数。  举个简单的例子: 

24分解质因数为2*2*2*3,简写成(2^3) * (3^1)。 


 在计算机方面,我们可以用一个哈希表来存储这个结果,在JS中可以用如下的形式表示: { '2': 3, '3': 1 } ,那么如何分解质因数呢? 


 首先,你需要一个判断是否为质数的方法:

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


然后,利用短除法来分解:

function PrimeFactorizer(n){
	//用来存储结果的hash
    var hash = {};
    while(n > 1){
		//从最小的质数开始除
        for(var i=2;i<=n;i++){
            if(isPrime(i) && n % i == 0){
				//如果hash中有这个质数,则存储的数目+1
                if(hash[i]){
                    hash[i] = hash[i] + 1;
                }//否则把该质数作为key,value为1
                else{
                    hash[i] = 1;
                }
				//除掉这个最小的质数因子
                n /= i;
            }
        }
    }
	//给实例上加个factor属性
    this.factor = hash;
    hash = null;
}
 
new PrimeFactorizer(24).factor // { '2': 3, '3': 1 }


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_1112