/*
struct TreeNode {
    int val;
    struct TreeNode *left;
    struct TreeNode *right;
    TreeNode(int x) :
            val(x), left(NULL), right(NULL) {
    }
};*/
class Solution {
  public:
    vector<vector<int>> FindPath(TreeNode* root, int expectNumber) {
		result.clear();
		path.clear();
		if (root == nullptr) return result;
		path.push_back(root->val);
		traversal(root, expectNumber - root->val);
		return result;
    }
    void traversal(TreeNode* cur, int count) {
        // 叶子节点且找到了和为sum的路径
        if (cur->left == nullptr && cur->right == nullptr && count == 0) {
            result.push_back(path);
            return;
        }
        if (cur->left == nullptr && cur->right == nullptr && count != 0) {
            return;
        }
        if (cur->left) {
            path.push_back(cur->left->val);
            count -= cur->left->val;
            traversal(cur->left, count);
            count += cur->left->val;
            path.pop_back();
        }

        if (cur->right) {
            path.push_back(cur->right->val);
            count -= cur->right->val;
            traversal(cur->right, count);
            count += cur->right->val;
            path.pop_back();
        }
		return;
    }
  private:
    vector<int> path;
    vector<vector<int>> result;
};