V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
shermer

想问下这个 js 的栈溢出怎么改呀~刚开始用 js 写算法 Orz

  •  
  •   shermer · Sep 27, 2021 · 1835 views
    This topic created in 1677 days ago, the information mentioned may be changed or developed.
    一个硬币的动态规划问题:

    var coinChange = function(coins, amount) {
    return dp(coins,amount);
    };

    var dp=function(coins,amount){
    if(amount==0) return 0;
    if(amount<0) return -1;
    let res =Infinity;
    for(let coin in coins)
    {
    let sub=dp(coins,amount-coin);
    if(sub==-1) continue;
    res=Math.min(res,sub+1);
    }
    return res==Infinity?-1:res;
    };


    然后在第二个函数里的第一句报了栈溢出
    5 replies    2021-09-27 01:54:09 +08:00
    shermer
        1
    shermer  
    OP
       Sep 27, 2021
    在线等~急~愁的睡不着了
    hsfzxjy
        2
    hsfzxjy  
       Sep 27, 2021 via Android
    数据规模多大?
    momocraft
        3
    momocraft  
       Sep 27, 2021
    递归改成循环
    Pipecraft
        4
    Pipecraft  
       Sep 27, 2021
    @shermer
    问题出在 array 的 for 循环用错了。
    `for(let coin in coins)`

    改成 `for (let coin of coins)`

    ```
    for (let i = 0; i < coins.length; i++) {
    const coin = coins[i];
    ```
    就可以了。
    Pipecraft
        5
    Pipecraft  
       Sep 27, 2021
    `for in` 循环的是下标,0,1,2...
    `amount-coin` 这里减 0 就导致无限循环了。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2651 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 36ms · UTC 03:14 · PVG 11:14 · LAX 20:14 · JFK 23:14
    ♥ Do have faith in what you're doing.