二叉樹中和為某一值的路徑

2021-10-09 20:58:20 字數 1074 閱讀 8121

輸入一顆二叉樹的根節點和乙個整數,按字典序列印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。

遞迴解法

/*

struct treenode

};*/

class solution

void findnumpath(treenode* root,int expectnumber,vector&onepath,vector> &result)

expectnumber = expectnumber - root->val;

findnumpath(root->left,expectnumber,onepath,result);

findnumpath(root->right,expectnumber,onepath,result);

onepath.pop_back();

return;

}};

非遞迴解法

/*

struct treenode

};*/

class solution

if(stk.top()->right)

}//如果葉子節點滿足

if(expectnumber == 0)

//出棧,遍歷到沒有入過棧的節點

while(stk.size()>0)}}

return result;

}};

非遞迴,後續遍歷

/*

struct treenode

};*/

class solution

if(stk.empty())break;

if(stk.top()->right == null ||stk.top()->right == pre)

expectnumber += pre->val;

nums.pop_back();

stk.pop();

}else

}return result;

}};

二叉樹中和為某一值的路徑

include include using namespace std struct node void find path node r,int exceptedsum,vector path,int cursum node buildbtree int a,int i void preorder...

二叉樹中和為某一值的路徑

要輸出所有的路徑,必須額外用乙個棧來儲存當前路徑資訊。當訪問到節點a時,節點a的資訊要在訪問a的左右子樹時用到,因而,該資訊必須在遍歷a的左右子樹前加入到棧中,而在遍歷完a的左右子樹後從棧中移除。每訪問乙個節點,就計算當前路徑值 可直接利用父節點的路徑值 當其等於給定值且當前節點是葉子節點時,就列印...

二叉樹中和為某一值的路徑

面試題25 二叉樹中和為某一值的路徑 struct binarytreenode int value binarytreenode pleft binarytreenode pright 分析 用先序遍歷的方式遍歷二叉樹,初始時路徑為空。訪問乙個結點時若不到葉子結點且結點的和小於這個值那麼就把這個結...