攻城狮凌风

每天一道算法题(9)——在二元树中找出和为某一值的所有路径

         题目:输入一个整数和一棵二元树。从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径。打印出和与输入整数相等的所有路径。

        例如输入整数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);

}




    

posted on 2015-05-26 15:58  攻城狮凌风  阅读(276)  评论(0编辑  收藏  举报

导航