输入一个整数和一棵二元树。
从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径。
从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径。
打印出和与输入整数相等的所有路径。
void help(int k, int cur, TNode* head, vector<int> vct) {
if (k <= cur || !head) {
return;
}
if (!head->left && !head->right && cur + head->data == k) {
for (int i = 0; i < vct.size(); ++i) {
cout << vct[i] << ' ';
}
cout << head->data << endl;
} else if (cur + head->data < k) {
if (head->left) {
vct.push_back(head->data);
help(k, cur + head->data, head->left, vct);
vct.pop_back();
}
if (head->right) {
vct.push_back(head->data);
help(k, cur + head->data, head->right, vct);
vct.pop_back();
}
}
}
void findPath(int k, TNode* head) {
vector<int> vct;
help(k, 0, head, vct);
}
本文介绍了一个算法,该算法接收一个整数及一棵二叉树作为输入,并找出所有从根节点到叶子节点路径上的节点之和等于给定整数的路径。通过递归方法实现,遍历所有可能的路径并比较其总和。
2252

被折叠的 条评论
为什么被折叠?



