zoukankan      html  css  js  c++  java
  • 每天一道算法题(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<<"
    "<<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);
    
    }
    




        

  • 相关阅读:
    互联网 DBA 需要做那些事(转)
    mysql_connect和mysql_pconnect区别(转)
    Redis应用案例,查找某个值的范围(转)
    PHP 正则表达式常用函数使用小结
    PHP转换UTF-8和GB2312的URL编码(转)
    PHP 打印调用函数入口地址(堆栈)
    php CI框架nginx 配置
    apache部署多个项目
    Apache+php在windows下的安装和配置
    appium测试之获取appPackage和appActivity
  • 原文地址:https://www.cnblogs.com/engineerLF/p/5393042.html
Copyright © 2011-2022 走看看