zoukankan      html  css  js  c++  java
  • 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.

    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]
    ]
    

    与Path Sum相比,本题是求出路径,所以,在找到满足的路径之后,不能直接返回,而是将其添加到一个vector<vector<int>>中。在查找的过程中,每经过一个结点,先使用一个vector<int>将该路径中的所有结点记录下来。由于vector<vector<int>>是用来记录所有满足的路径的,所以传递引用给它是为了对它的每一个改动都是对其本身的操作,而不是对其副本的操作,使用来返回找到的所有路径。使用的vector<int>只是拷贝操作,所以都是对其副本的操作,不会对原始的vector<int>有影响。

    C++代码实现:

    #include<iostream>
    #include<new>
    #include<vector>
    using namespace std;
    
    //Definition for binary tree
    struct TreeNode
    {
        int val;
        TreeNode *left;
        TreeNode *right;
        TreeNode(int x) : val(x), left(NULL), right(NULL) {}
    };
    
    class Solution
    {
    public:
        vector<vector<int> > pathSum(TreeNode *root, int sum)
        {
            vector<vector<int> > path;
            vector<int> tmp;
            hasPathSum(root,sum,path,tmp);
            return path;
        }
        void hasPathSum(TreeNode *root, int sum,vector<vector<int> > &path,vector<int> tmp)
        {
            if(root==NULL)
                return;
            tmp.push_back(root->val);
            if(root->left==NULL&&root->right==NULL&&(sum-root->val)==0)
            {
                path.push_back(tmp);
            }
            if(root->left)
                hasPathSum(root->left,sum-root->val,path,tmp);
            if(root->right)
                hasPathSum(root->right,sum-root->val,path,tmp);
        }
        void createTree(TreeNode *&root)
        {
            int i;
            cin>>i;
            if(i!=0)
            {
                root=new TreeNode(i);
                if(root==NULL)
                    return;
                createTree(root->left);
                createTree(root->right);
            }
        }
    };
    int main()
    {
        Solution s;
        TreeNode *root;
        s.createTree(root);
        vector<vector<int> > path=s.pathSum(root,6);
        for(auto a:path)
        {
            for(auto v:a)
                cout<<v<<" ";
            cout<<endl;
        }
    }

    运行结果:

     
  • 相关阅读:
    poj 2942 Knights of the Round Table 双连通分量
    zoj 2588 Burning Bridges 桥
    desin pattern
    android
    ubuntu
    centos
    android布局
    gradle
    好站
    tomcat datasource
  • 原文地址:https://www.cnblogs.com/wuchanming/p/4101055.html
Copyright © 2011-2022 走看看