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);
    
    }
    




        

  • 相关阅读:
    麒麟短线王实战技法
    Silverlight的资源
    Windows Live SkyDrive, Windows Live Sync 和 Live Mesh
    Listview.Subitem.BackColor.ForeColor改变字体颜色和背景
    windows mobile控制面板程序
    Windows Azure百度百科
    wcf中如何Host多个WCF服务?
    强弱跟踪
    修改默认的HTTP Response Header
    DataTable 内部索引已损坏
  • 原文地址:https://www.cnblogs.com/engineerLF/p/5393042.html
Copyright © 2011-2022 走看看