非递归实现树的后序遍历

前序遍历是通过一个stack,首先压入父亲结点,然后弹出父亲结点,并输出它的value,之后压人其右儿子,左儿子即可。然而后序遍历结点的访问顺序是:左儿子 -> 右儿子 -> 自己。那么一个结点需要两种情况下才能够输出:第一,它已经是叶子结点;第二,它不是叶子结点,但是它的儿子已经输出过。那么基于此我们只需要记录一下当前输出的结点即可。对于一个新的结点,如果它不是叶子结点,儿子也没有访问,那么就需要将它的右儿子,左儿子压入。如果它满足输出条件,则输出它,并记录下当前输出结点。输出在stack为空时结束。

class Solution {  
public:  
    vector<int> postorderTraversal(TreeNode *root) {  
        // IMPORTANT: Please reset any member data you declared, as  
        // the same Solution instance will be reused for each test case.  
        vector<int> path;  
        if(root==NULL)return path;  
  
        stack<TreeNode*> stk;  
        stk.push(root);  
        TreeNode* cur = NULL;  
        while(!stk.empty())  
        {  
            cur = stk.top();  
            if(cur->left ==NULL && cur->right ==NULL)  
            {  
                path.push_back(cur->val);  
                stk.pop();  
            }else{  
                if(cur->right)  
                {  
                    stk.push(cur->right);  
                    cur->right = NULL;  
                }  
                if(cur->left)  
                {  
                    stk.push(cur->left);  
                    cur->left = NULL;  
                }  
            }  
        }  
        return path;  
    }  
};  


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值