• 每天一道算法题(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);
    
    }
    




        

  • 相关阅读:
    软件开发测试模式:迭代→全功能模式
    LUN挂载到Linux主机后,如何对磁盘进行分区
    MySQL性能优化方法四:SQL优化
    MySQL性能优化方法三:索引优化
    MySQL性能优化方法二:表结构优化
    MySQL性能优化方法一:缓存参数优化
    MySQL配置文件my.ini或my.cnf的位置
    javascript今生前世
    如何在sublime中使用sass
    全栈最后一公里
  • 原文地址:https://www.cnblogs.com/engineerLF/p/5393042.html
Copyright © 2020-2023  润新知