zoukankan      html  css  js  c++  java
  • LeetCode: Path Sum

    LeetCode: Path Sum

    Given a binary tree and a sum, determine if the tree has a root-to-leaf path such that adding up all the values along the path equals the given sum.

    For example:
    Given the below binary tree and sum = 22,

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

    return true, as there exist a root-to-leaf path 5->4->11->2 which sum is 22.

    地址:https://oj.leetcode.com/problems/path-sum/

    算法:用递归应该很简单吧。直接看代码吧:

     1 /**
     2  * Definition for binary tree
     3  * struct TreeNode {
     4  *     int val;
     5  *     TreeNode *left;
     6  *     TreeNode *right;
     7  *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     8  * };
     9  */
    10 class Solution {
    11 public:
    12     bool hasPathSum(TreeNode *root, int sum) {
    13         if(!root)   return false;
    14         return subSolution(root,sum);
    15     }
    16     bool subSolution(TreeNode *root, int sum){
    17         if(!root->left && !root->right){
    18             if(sum == root->val)    return true;
    19             else    return false;
    20         }else{
    21             if(root->left){ 
    22                 bool left = subSolution(root->left,sum - root->val);
    23                 if(left)    return true;
    24             }
    25             if(root->right){
    26                 bool right = subSolution(root->right,sum - root->val);
    27                 if(right)   return true;
    28             }
    29         }
    30         return false;
    31     }
    32 };

    第二题:

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

    For 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]
    ]
    
    地址:https://oj.leetcode.com/problems/path-sum-ii/
    算法:跟上一题一样,只不过必须返回所有的结果。应该也很简单,直接看代码:
     1 /**
     2  * Definition for binary tree
     3  * struct TreeNode {
     4  *     int val;
     5  *     TreeNode *left;
     6  *     TreeNode *right;
     7  *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     8  * };
     9  */
    10 class Solution {
    11 public:
    12     vector<vector<int> > pathSum(TreeNode *root, int sum) {
    13         if(!root)   return vector<vector<int> >();
    14         return subPathSum(root,sum);
    15     }
    16     vector<vector<int> > subPathSum(TreeNode *root, int sum){
    17         if(!root->left && !root->right){
    18             if(root->val == sum){
    19                 return vector<vector<int> >(1,vector<int>(1,sum)); 
    20             }else{
    21                 return vector<vector<int> >();
    22             }
    23         }
    24         vector<vector<int> > result;
    25         if(root->left){
    26             vector<vector<int> > left = subPathSum(root->left, sum - root->val);
    27             vector<vector<int> >::iterator it = left.begin();
    28             for(; it != left.end(); ++it){
    29                 vector<int> temp;
    30                 temp.push_back(root->val);
    31                 temp.insert(temp.end(),it->begin(),it->end());
    32                 result.push_back(temp);
    33             }
    34         }
    35         if(root->right){
    36             vector<vector<int> > right = subPathSum(root->right,sum - root->val);
    37             vector<vector<int> >::iterator it = right.begin();
    38             for(; it != right.end(); ++it){
    39                 vector<int> temp;
    40                 temp.push_back(root->val);
    41                 temp.insert(temp.end(),it->begin(),it->end());
    42                 result.push_back(temp);
    43             }
    44         }
    45         return result;
    46     }
    47 };
  • 相关阅读:
    JS—超酷时钟
    JS—简单年历表
    ZZULI 1783 简单的求和
    ZZULI 1788 小金刚的宝藏(01背包模板)
    HDU 5172 GTY's gay friends(BestCoder Round #29)
    HDU 2157 How many ways??
    HDU 5171 GTY's birthday gift(BestCoder Round #29)
    在SQL Server 中启用 FileStream
    (转载)SQL Server的一个不显眼的功能 备份文件的分割
    面向对象建模方法与数据库建模方法的比较
  • 原文地址:https://www.cnblogs.com/boostable/p/leetcode_path_sum.html
Copyright © 2011-2022 走看看