JS实现找第n个丑数(动态规划)

丑数是指质因数只有2,3,5,特殊的,1也是质因数,昨天在中国结算遇到了这道题,但是没有做出来,直到看了思想才明白,今天自己写了一遍,也算是提醒.

编程语言:JavaScript


function choushu(num){
    var arr = [1];

    var T2 = 0, T3 = 0,T5 = 0;
    var temp2 = 0, temp3 = 0, temp5 = 0;
    var nextone=0;

    console.log("第1个丑数是 "+arr[arr.length-1]);
    while(arr.length<num){
        temp2 = arr[T2]*2;
        temp3 = arr[T3]*3;
        temp5 = arr[T5]*5;

        nextone = min(temp2,temp3,temp5);
        arr.push(nextone);
        console.log("第"+arr.length+"个丑数是 "+arr[arr.length-1]);
        if(nextone>=temp2){T2++;}
        if(nextone>=temp3){T3++;}
        if(nextone>=temp5){T5++;}
    }
}
function min(num1,num2,num3) {

    return num1<num2?(num1<num3?num1:num3):(num2<num3?num2:num3);
}
choushu(100)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值