求二叉树指定结点到根的路径c语言,二叉树根节点到叶子结点和为指定值的路径...

题目描述

b9817da33ba3

image.png

题解

解题思路与二叉树根节点到叶节点的所有路径和一题相似,都是采用递归算法。但这个题加了一点,要求保存路径到vector中。

为了保存路径,这里给递归函数传递一个vector类型的参数,用于保存从根节点到当前节点的路径。将当前节点值追加到vector末尾,再向下层传递。当到达叶节点时,判断是否符合条件,如果符合,就将该路径加到结果中。

到叶节点就可以完成判断并得到路径了,所以递归函数不需要返回值。

代码

// pathSum.cpp

#include

#include

using namespace std;

struct TreeNode {

int val;

struct TreeNode *left;

struct TreeNode *right;

TreeNode(int val){

this->val = val;

this->left = NULL;

this->right = NULL;

}

};

class Solution {

public:

/**

*

* @param root TreeNode类

* @param sum int整型

* @return int整型vector>

*/

vector > pathSum(TreeNode* root, int sum) {

// write code here

if (root == NULL){

return meet;

}

vector path;

targetSum = sum;

sumNumbers(root, root->val, path);

return meet;

}

private:

vector> meet;

int targetSum;

void sumNumbers(TreeNode* t, int sum, vector path){

path.push_back(t->val);

if (t->left == NULL && t->right == NULL){

if (sum == targetSum){

meet.push_back(path);

}

}

if (t->left != NULL){

sumNumbers(t->left, t->left->val + sum, path);

}

if (t->right != NULL){

sumNumbers(t->right, t->right->val + sum, path);

}

}

};

int main()

{

TreeNode* root = new TreeNode(5);

TreeNode* left = new TreeNode(4);

TreeNode* right = new TreeNode(8);

TreeNode* leftleft = new TreeNode(1);

TreeNode* leftright = new TreeNode(11);

TreeNode* leftrightleft = new TreeNode(2);

TreeNode* leftrightright = new TreeNode(7);

TreeNode* rightright = new TreeNode(9);

root->left = left;

root->right = right;

left->left = leftleft;

left->right = leftright;

leftright->left = leftrightleft;

leftright->right = leftrightright;

right->right = rightright;

Solution s;

vector> meet = s.pathSum(root, 22);

for (int i = 0; i < meet.size(); i++){

for (int j = 0; j < meet[i].size(); j++){

cout << meet[i][j] << " ";

}

cout << endl;

}

delete root;

delete left;

delete right;

delete leftleft;

delete leftright;

delete leftrightleft;

delete leftrightright;

delete rightright;

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值