题解 | #质数因子#

质数因子

http://www.nowcoder.com/practice/196534628ca6490ebce2e336b47b3607

//质数因子:首先要知道什么叫质数因子了,任何大于1的数都能被拆分成若干个质数的乘积,另外X的质因子一定小于等于根号X,即质因子的范围为2到√X
//另外还有个特殊情况,就是输入的这个数,本身就是质数,但还要排除1这个数。
let num = parseInt(readline());
let arr = []
function getCode(num){
    let i = 2,tep = num;
    while(i <= tep && i * i <= tep){
        while(num % i == 0){
            arr.push(i);
            num /= i;
        }
        ++i;
    }
    if(num != 1){
        arr.push(num);
    }

    arr.push(',');
    return arr;
}

let res = getCode(num);
console.log(res.join(',').replace(/,/gu,' '))
全部评论
最后直接join(" ")就行了
1 回复 分享
发布于 2021-11-14 22:24
可以写成while(n <= Math.sqrt(num)),不用临时变量tep了
1 回复 分享
发布于 2021-12-13 22:36
能问一下/,/gu,' '是什么意思吗?
点赞 回复 分享
发布于 2022-02-09 20:30
X的质因子一定小于等于根号X,这句话不对哦,10的质因子是2、5,而5>大于根号10
4 回复 分享
发布于 2022-06-08 18:18
加上 i * i <= tep 是怎么来的呢?
点赞 回复 分享
发布于 2022-04-19 23:48
i <= tep是不是多余条件
点赞 回复 分享
发布于 2022-09-19 01:08 广东

相关推荐

牛客618272644号:佬携程工作怎么样,强度大吗
点赞 评论 收藏
分享
23 4 评论
分享
牛客网
牛客企业服务