题解 | #质数因子#

质数因子

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

相关推荐

不愿透露姓名的神秘牛友
07-01 11:47
点赞 评论 收藏
分享
评论
24
4
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务