【LeetCode】437. Path Sum III

You are given a binary tree in which each node contains an integer value.

Find the number of paths that sum to a given value.

The path does not need to start or end at the root or a leaf, but it must go downwards (traveling only from parent nodes to child nodes).

The tree has no more than 1,000 nodes and the values are in the range -1,000,000 to 1,000,000.

Example:

root = [10,5,-3,3,2,null,11,3,-2,null,1], sum = 8

      10
     /  \
    5   -3
   / \    \
  3   2   11
 / \   \
3  -2   1

Return 3. The paths that sum to 8 are:

1.  5 -> 3
2.  5 -> 2 -> 1
3. -3 -> 11

题解:

  此题类似于字符串或者数组的区间问题,区间和、乘积等。最直接的思想就是枚举所有可能区间。此题先遍历树,在遍历过程中对遍历节点枚举以其为始点的所有区间的和是否等于sum。

Solution 1

 1 class Solution {
 2 public:
 3     int pathSum(TreeNode* root, int sum) {
 4         if (!root)
 5             return 0;
 6         int res = 0;
 7         stack<TreeNode*> st;
 8         TreeNode* cur = root;
 9         while (cur || !st.empty()) {
10             if (cur) {
11                 st.push(cur);
12                 cur = cur->left;
13             } else {
14                 cur = st.top();
15                 st.pop();
16                 int num = 0;
17                 dfs(cur, num, sum);
18                 res += num;
19                 cur = cur->right;
20             }
21         }
22         return res;
23     }
24     void dfs(TreeNode* root, int& num, int sum) {
25         if (!root)
26             return;
27         if (root->val == sum) {
28             ++num;
29         }
30         dfs(root->left, num, sum - root->val);
31         dfs(root->right, num, sum - root->val);
32         
33     }
34 };

 

Solution 2

  以root为根节点的树的sum = 以root为起点的区间满足条件的个数 + 以root左孩子为根节点的树的sum + 以root右孩子根节点的树的sum,得到递推关系。

  注意 dfs 搜索的是以root为起点的区间,而pathSum搜索的是以root为根节点的树,pathSum没有要求区间必须以root为起点。

 1 class Solution {
 2 public:
 3     int pathSum(TreeNode* root, int sum) {
 4         if (!root)
 5             return 0;
 6         return dfs(root, sum) + pathSum(root->left, sum) + pathSum(root->right, sum);
 7     }
 8     int dfs(TreeNode* root, int sum) {
 9         int num = 0;
10         if (!root)
11             return 0;
12         if (root->val == sum) {
13             ++num;
14         }
15         num += dfs(root->left, sum - root->val);
16         num += dfs(root->right, sum - root->val);
17         return num;
18     }
19 };

 

Solution 3

  思路用的是数组字符串区间常用的哈希存储思想,一般来讲树上不太常用,严格来讲应该和前缀和有些相似。Grandyang

 1 class Solution {
 2 public:
 3     int pathSum(TreeNode* root, int sum) {
 4         unordered_map<int, int> m;
 5         m[0] = 1;
 6         return helper(root, sum, 0, m);
 7     }
 8     
 9     int helper(TreeNode* node, int sum, int curSum, unordered_map<int, int>& m) {
10         if (!node) 
11             return 0;
12         curSum += node->val;
13         int res = m[curSum - sum];
14         ++m[curSum];
15         res += helper(node->left, sum, curSum, m) + helper(node->right, sum, curSum, m);
16         --m[curSum];
17         return res;
18     }
19 };

 

posted @ 2018-04-14 21:53  Vincent丶丶  阅读(178)  评论(0编辑  收藏  举报