Fighting IT 2023-06-24 12:45 采纳率: 0%
浏览 9

判断尾递归好坏的策略与方法?

最近看了些代码,频繁看到递归的写法。无意中想起尾递归,例如时间复杂度、受制于栈空间、while循环替换等等。作为CSDN的粉丝,好奇下,提出第一个问题,讨论下尾递归。如有CSDN用户提供解答方案,不胜感激。🙂

  • 写回答

2条回答 默认 最新

  • 竹山全栈 2023-06-24 13:11
    关注

    一般是在尾递归形式下引入一个新的参数 比如result,用来记录当前计算结果。在每次递归调用中,都将 result 乘以当前计算的数 n,然后将 n 减1。当 n 的值小于等于1时,停止递归调用,直接返回计算结果 result。
    尾递归并不是解决所有递归函数问题的万能方法有些复杂的递归函数可能无法轻易改写为尾递归形式,此时需要寻找其他适当的算法或数据结构来解决问题

    评论

报告相同问题?

问题事件

  • 创建了问题 6月24日

悬赏问题

  • ¥15 俄罗斯方块中无法同时消除多个满行
  • ¥15 c#转安卓 java html
  • ¥15 os.listdir文件路径找不到
  • ¥15 使用gojs3.0,如何在nodeDataArray设置好text的位置,再go.TextBlock alignment中进行相应的改变
  • ¥15 psfusion图像融合指标很低
  • ¥15 银河麒麟linux系统如何修改/etc/hosts权限为777
  • ¥50 医院HIS系统代码、逻辑学习
  • ¥30 docker离线安装mysql报错,如何解决?
  • ¥15 构建工单的总账影响在哪里查询或修改
  • ¥15 三个简单项目写完之后有重赏之后联系我