查看: 244|回复: 0
收起左侧

[树/链表/图] 请问可以用tail recursion来解决tree traversal吗?

|只看干货
shuatizhe | 显示全部楼层 |阅读模式
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   80% (4)
 
 
20% (1)    👎

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
本帖最后由 shuatizhe 于 2022-1-17 22:12 编辑

比如,preOrder tree traversal,一般都是这样递归:
  1. public class Solution {
  2.     public List<Integer> preorderTraversal(TreeNode root) {
  3.         List<Integer> result = new ArrayList<Integer>();
  4.         traverse(root, result);
  5.         return result;
  6.     }

  7.     private void traverse(TreeNode root, List<Integer> result) {
  8.         if (root == null) {
  9.             return;
  10.         }

  11.         result.add(root.val);               
  12.         traverse(root.left, result);               
  13.         traverse(root.right, result);
  14.     }
  15. }
复制代码
但是这不是尾递归,如果要换成尾递归就要把 result.add(root.val)也放到traverse( )参数中,试了几种方法,都不对。知道有没有尾递归的解法?谢谢!



评分

参与人数 1大米 +3 收起 理由
14417335 + 3 给你点个赞!

查看全部评分


上一篇:【学习分享】Python刷题持续更新 - 涵盖题目/笔记/答案
下一篇:刷题进阶求教
您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表