题目描述
输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。
class Solution {
private:
vector<vector<int> > result;
void findnode(TreeNode *root, const int expectNumber,int sum,vector<int> &path)
{
if (root == NULL)
{
return;
}
path.push_back(root->val);
sum += root->val;
if (!root->left && !root->right && sum == expectNumber)
{
result.push_back(path);
}
else {
findnode(root->left,expectNumber,sum,path);
findnode(root->right,expectNumber,sum,path);
}
path.pop_back();
sum -= root->val;
}
public:
vector<vector<int> > FindPath(TreeNode* root, int expectNumber)
{
vector<int> path;
findnode(root,expectNumber,0,path);
return result;
}
};