113. Path Sum II

Given a binary tree and a sum, find all root-to-leaf paths where each path's sum equals the given sum.

Note: A leaf is a node with no children.

Example:

Given the below binary tree and sum = 22,

      5
     / \
    4   8
   /   / \
  11  13  4
 /  \    / \
7    2  5   1

Return:

[
   [5,4,11,2],
   [5,8,4,5]
]

 -

复制代码
 private List<IList<int>> list = new List<IList<int>>();

        public IList<IList<int>> PathSum(TreeNode root, int sum)
        {
            Chuck(root, sum, 0, string.Empty);
            return list;
        }

        private void Chuck(TreeNode node, int sum, int tempSum, string str)
        {
            if (node == null)
            {
                return;
            }

            tempSum = tempSum + node.val;
            var left = node.left;
            var right = node.right;
            if (string.IsNullOrEmpty(str))
            {
                str = $"{node.val}";
            }
            else
            {
                str = $"{str},{node.val}";
            }

            if (left == null && right == null)
            {
                if (tempSum == sum)
                {
                    var tempList = str.Split(',').Select(x => Convert.ToInt32(x)).ToList();
                    list.Add(tempList);
                }
            }
            else
            {
                Chuck(left, sum, tempSum, str);
                Chuck(right, sum, tempSum, str);
            }
        }
复制代码
Runtime: 288 ms, faster than 21.95% of C# online submissions for Path Sum II.
Memory Usage: 34.2 MB, less than 13.98% of C# online submissions forPath Sum II.

 

作者:Chuck Lu    GitHub    
posted @   ChuckLu  阅读(144)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
历史上的今天:
2017-05-26 wcf rest系列文章
2016-05-26 XmlSerializer
点击右上角即可分享
微信分享提示