zknlz 2023-04-23 17:29 采纳率: 75%
浏览 9

leetcode144前序遍历递归问题


        def dfs(root):
            res = []
            if root == None:
                return res
            res.append(root.val)
            dfs(root.left)
            dfs(root.right)

            return res

Input
root =
[1,null,2,3]
Output
[]
我是用递归解法 请问问题出在哪里?

  • 写回答

1条回答 默认 最新

  • Leodong. 2023-04-23 17:34
    关注

    该回答通过自己思路及引用到GPTᴼᴾᴱᴺᴬᴵ搜索,得到内容具体如下:
    你的代码递归逻辑本身没有问题,但在 dfs(root.left)dfs(root.right) 这两行代码中,返回的遍历结果没有被保存在 res 中,这就导致最终的结果是一个空列表 []。因此,你需要将这两行代码修改为:

    res.extend(dfs(root.left))
    res.extend(dfs(root.right))
    

    这样,在递归遍历左子树和右子树时,返回的结果会被添加到 res 列表中。修改后的完整代码如下:

    class Solution:
        def preorderTraversal(self, root: TreeNode) -> List[int]:
            def dfs(root):
                res = []
                if root == None:
                    return res
                res.append(root.val)
                res.extend(dfs(root.left))
                res.extend(dfs(root.right))
    
                return res
            
            return dfs(root)
    

    希望能帮助到你。


    如果以上回答对您有所帮助,点击一下采纳该答案~谢谢

    评论

报告相同问题?

问题事件

  • 创建了问题 4月23日

悬赏问题

  • ¥15 is not in the mmseg::model registry。报错,模型注册表找不到自定义模块。
  • ¥15 安装quartus II18.1时弹出此error,怎么解决?
  • ¥15 keil官网下载psn序列号在哪
  • ¥15 想用adb命令做一个通话软件,播放录音
  • ¥30 Pytorch深度学习服务器跑不通问题解决?
  • ¥15 部分客户订单定位有误的问题
  • ¥15 如何在maya程序中利用python编写领子和褶裥的模型的方法
  • ¥15 Bug traq 数据包 大概什么价
  • ¥15 在anaconda上pytorch和paddle paddle下载报错
  • ¥25 自动填写QQ腾讯文档收集表