Morris 先序遍历

/*************************************************************************
  * File Name: Solution.cpp
  * Description: 
  * Author: Yuji CAO
  * Mail: caoyuji@sogou-inc.com
  * Created_Time: 2015-07-29 17时40分29秒
  * Last modified: 2015-07-29 17时40分29秒
 ************************************************************************/
#include<stdio.h>
#include<vector>
using namespace std;
struct TreeNode{
    int _val;
    TreeNode* _left;
    TreeNode* _right;
    TreeNode(int val):_val(val),_left(NULL),_right(NULL){}
};
void preTravel(TreeNode* root,vector<int>& ret){
    TreeNode* cur=root;
    while(cur){
        if(cur->_left==NULL){
            ret.push_back(cur->_val);
            cur=cur->_right;
        }else{
            TreeNode* node=cur->_left;
            while(node->_right!=NULL&&node->_right!=cur){
                node=node->_right;
            }
            if(node->_right==cur){//already trailed
                ret.push_back(cur->_val);
                node->_right=NULL;
                cur=cur->_right;
            }else{//not trailed
                node->_right=cur;
                cur=cur->_left;
            }
        }
    }
}
int main(){
    vector<int> ret;
    TreeNode *root=new TreeNode(1);

    root->_left=new TreeNode(2);
    root->_right=new TreeNode(3);

    root->_left->_left=new TreeNode(4);
    root->_left->_right=new TreeNode(5);
    root->_right->_left=new TreeNode(6);
    root->_right->_right=new TreeNode(7);

    root->_left->_left->_left=new TreeNode(8);
    root->_left->_right->_right=new TreeNode(10);

    root->_left->_left->_left->_right=new TreeNode(9);

    preTravel(root,ret);
    for(auto ele:ret){
        printf("%3d",ele);
    }
    putchar('\n');
    return 0;
}

分析

充分利用空闲指针,空间复杂度O(1)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值