日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

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

發布時間:2025/3/20 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 求二叉树指定结点到根的路径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语言,二叉树根节点到叶子结点和为指定值的路径...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。