算法思想:采用后序非递归遍历,访问到值为x的结点时,栈中所有元素均为该节点的祖先节点。
 void postorderTraversal(TreeNode* root) {
        TreeNode *r;
        TreeNode *p=root;
        stack<TreeNode*> s;
        while(!s.empty()||p){
            if(p){
                s.push(p);
                p=p->left;
            }else{
                p=s.top();
                if(p->right&&p->right!=r){
                     p=p->right;
                     s.push(p);
                     p=p->left;
                }else{
                    r=s.top();
                    s.pop();
                    if(r->val==9){
                        while(!s.empty()){
                            cout<<s.top()->val<<" ";
                            s.pop();
                        }
                        break;
                    }
                    p=NULL;
                }
            }
        }
    }
 
                   
                   
                   
                   
                             
       
           
                 
                 
                 
                 
                 
                
               
                 
                 
                 
                 
                
               
                 
                 扫一扫
扫一扫
                     
              
             
                   389
					389
					
 被折叠的  条评论
		 为什么被折叠?
被折叠的  条评论
		 为什么被折叠?
		 
		  到【灌水乐园】发言
到【灌水乐园】发言                                
		 
		 
    
   
    
   
             
            


 
            