日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

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

發(fā)布時(shí)間:2025/3/20 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 求二叉树指定结点到根的路径c语言,二叉树根节点到叶子结点和为指定值的路径... 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

題目描述

image.png

題解

解題思路與二叉樹(shù)根節(jié)點(diǎn)到葉節(jié)點(diǎn)的所有路徑和一題相似,都是采用遞歸算法。但這個(gè)題加了一點(diǎn),要求保存路徑到vector中。

為了保存路徑,這里給遞歸函數(shù)傳遞一個(gè)vector類(lèi)型的參數(shù),用于保存從根節(jié)點(diǎn)到當(dāng)前節(jié)點(diǎn)的路徑。將當(dāng)前節(jié)點(diǎn)值追加到vector末尾,再向下層傳遞。當(dāng)?shù)竭_(dá)葉節(jié)點(diǎn)時(shí),判斷是否符合條件,如果符合,就將該路徑加到結(jié)果中。

到葉節(jié)點(diǎn)就可以完成判斷并得到路徑了,所以遞歸函數(shù)不需要返回值。

代碼

// 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類(lèi)

* @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;

}

總結(jié)

以上是生活随笔為你收集整理的求二叉树指定结点到根的路径c语言,二叉树根节点到叶子结点和为指定值的路径...的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。