每天一道算法题(9)——在二元树中找出和为某一值的所有路径
来源:互联网 发布:怎么把产品放到淘宝上 编辑:程序博客网 时间:2024/04/26 13:06
题目:输入一个整数和一棵二元树。从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径。打印出和与输入整数相等的所有路径。
例如输入整数22 和如下二元树
10
/ \
5 12
/ \
4 7
则打印出两条路径:10, 12 和10, 5, 7。1.思路
使用递归和栈结构。将当前路径保留在vector中。
(1)对于空节点,返回false;
(2)对于叶子节点,判断当前和是否为给定值,是则遍历输出栈中保存路径且返回true,否则返回false。
(3) 对于非叶子节点,将当前根节点入栈,先后递归左、右子树。且递归完后,要弹出栈中保存的当前路径。
2.代码
#include"iostream"#include"vector"using namespace std;struct Node // a node in the binary search tree{ int value; // value of node Node* left; // left child of node Node* right; // right child of node};bool decision(Node* Head,int sum,vector<int>& v){ if(!Head){//空节点 return false; } else if(!Head->left&&!Head->right){//为叶子节点 sum-=Head->value; if(sum==0){//为有效路径,输出for(int i=0;i<v.size();i++)cout<<v[i]<<endl;cout<<Head->value<<"\n"<<endl;return true; } return false; } else{//非叶子节点,对左右子树进行遍历v.push_back(Head->value);sum-=Head->value;bool left=decision(Head->left,sum,v);bool right=decision(Head->right,sum,v);v.pop_back();if(left||right)return true;}return false;}void main(){Node n4={4,NULL,NULL};Node n5={7,NULL,NULL};Node n3={12,NULL,NULL};Node n2={5,&n4,&n5};Node n1={10,&n2,&n3}; vector<int> v; decision(&n1,22,v);}
0 0
- 每天一道算法题(9)——在二元树中找出和为某一值的所有路径
- 每日一道算法题4——在二元树中找出和为某一值的所有路径
- 算法面试100题——4.在二元树中找出和为某一值的所有路径
- 每天一算法(在二元树中找出和为某一值的所有路径(树))
- 算法题23 在二元树中找出和为某一值的所有路径
- 在二元树中找出和为某一值的所有路径-递归算法
- 算法讨论(三)---在二元树中找出和为某一值的所有路径
- 【算法】在二元树中找出和为某一值的所有路径
- 算法习题5:在二元树中找出和为某一值的所有路径
- 微软算法100道题------在二元树中找出和为某一值的所有路径
- 每天三道冲刺工作--在二元树中找出和为某一值的所有路径
- 面试100题:4.在二元树中找出和为某一值的所有路径
- 面试100题:4.在二元树中找出和为某一值的所有路径
- 第四题(在二元树中找出和为某一值的所有路径)
- 微软编程题之在二元树中找出和为某一值的所有路径
- 解题笔记(6)——在二元树中找出和为某一值的所有路径(树)
- 【面试题】在二元树中找出和为某一值的所有路径——Java实现
- 算法与数据结构面试题(4)-在二元树中找出和为某一值的所有路径
- IDEA+TOMCAT+JSTL,jsp页面异常
- PIC单片机烧录后不启动,用手触摸板子偶尔可以工作,
- 海量数据处理---分布式处理之MapReduce
- Android系统属性分析ro.persist.
- 关于NS2的安装
- 每天一道算法题(9)——在二元树中找出和为某一值的所有路径
- Java swing入门教程(转载)
- Java并发编程--线程局部变量使用
- 大数据技术-HBase:HBase 日志划分详解
- C#双缓冲
- 数据结构运动会分数统计实习报告源码
- python程序获取当前行号和文件名
- android背景选择器selector用法汇总
- Thinking in Java---多态初探