欢迎访问 生活随笔!

生活随笔

当前位置: 首页 >

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

发布时间:2025/3/20 42 豆豆
生活随笔 收集整理的这篇文章主要介绍了 求二叉树指定结点到根的路径c语言,二叉树根节点到叶子结点和为指定值的路径... 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

题目描述

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;

}

总结

以上是生活随笔为你收集整理的求二叉树指定结点到根的路径c语言,二叉树根节点到叶子结点和为指定值的路径...的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。