为了账号安全,请及时绑定邮箱和手机立即绑定

反转数字的递归函数

反转数字的递归函数

萧十郎 2023-03-03 09:51:19
我尝试使用递归函数来反转它有效的数字,但对于一个调用来说,我猜只是因为作用域,但我不知道如何修复它let num;let reversed='';let result; function reverseNum(n){    for(let i =0; i<n; i++){      num = n%10; // get the last digit e.g 352 %10 = 2    reversed+= num    result = parseInt(n / 10); // remove last digit e.g. parseInt(352/10) = 35    reverseNum(result);    if(result ===0){         break;    }   }  return reversed;}
查看完整描述

1 回答

?
潇潇雨雨

TA贡献1833条经验 获得超4个赞

每次从外部调用函数时,您都需要重新创建num、reversed和变量。result这是一个简单的调整,通过在 top 函数中定义递归函数reverseNum:


function reverseNum(n) {

  let num;

  let reversed = '';

  let result;

  const recurse = (n) => {

    for (let i = 0; i < n; i++) {

      num = n % 10; // get the last digit e.g 352 %10 = 2

      reversed += num

      result = parseInt(n / 10); // remove last digit e.g. parseInt(352/10) = 35

      recurse(result);

      if (result === 0) {

        break;

      }

    }

    return reversed;

  };

  return recurse(n);

}


console.log(reverseNum(1234));

console.log(reverseNum(1234));

但更优雅的方法是:


function reverseNum(n, str = String(n)) {

  const thisDigit = str[str.length - 1];

  const recursiveResult = str.length === 1 ? '' : reverseNum(str.slice(0, str.length - 1));

  return Number(thisDigit + recursiveResult);

}


console.log(reverseNum(1234));

console.log(reverseNum(1234));


查看完整回答
反对 回复 2023-03-03
  • 1 回答
  • 0 关注
  • 123 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信