面试题34. 二叉树中和为某一值的路径

https://leetcode-cn.com/problems/er-cha-shu-zhong-he-wei-mou-yi-zhi-de-lu-jing-lcof/

var path = [Int]()
var result = [[Int]]()

func pathSum(_ root: TreeNode?, _ sum: Int) -> [[Int]] {
    pathSumAction(root, sum)
    return result
}

func pathSumAction(_ root: TreeNode?, _ sum: Int) {
    if root == nil {
        return
    }
    var Sum = sum
    //记录经过的路径
    path.append(root!.val)
    Sum = Sum - root!.val
    //判断路径是否符合
    if Sum == 0 && root?.left == nil && root?.right == nil {
        result.append(path)
    }
    //前序遍历
    pathSumAction(root?.left, Sum)
    pathSumAction(root?.right, Sum)
    //返回上一节点路径
    path.removeLast()
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容