题解 | #二叉搜索树与双向链表#

二叉搜索树与双向链表

http://www.nowcoder.com/practice/947f6eb80d944a84850b0538bf0ec3a5

//中序遍历 + 非递归 
class Solution {
public:
    TreeNode* Convert(TreeNode* root) {
        stack<TreeNode*> st;
        TreeNode *last_visit=nullptr, *ans=nullptr;
        while(!st.empty() || root)
        {
            while(root)
            {
                st.push(root);
                root = root->left;
            }
            root = st.top();
            st.pop();
            if(last_visit == nullptr) 
            {
                ans = root;
            }
            else
            {
                root->left = last_visit;
                last_visit->right = root;
            }
            last_visit = root;
            root = root->right;
        }
        return ans;
    }
};
//中序遍历 + 递归(全局变量)
class Solution {
public:
    TreeNode* Convert(TreeNode* root) {
        if(!root) return nullptr;
        Convert(root->left);
        if(last_visit == nullptr)
        {
            ans = root;
        }
        else
        {
            root->left = last_visit;
            last_visit->right = root;
        }
        last_visit = root;
        Convert(root->right);
        return ans;
    }
private:
    TreeNode *ans=nullptr, *last_visit=nullptr;
};
全部评论

相关推荐

03-12 09:57
软件测试
程序员小白条:1)确定测试,测开的方向,技术栈不能写这么少 2)课程凑数的,不是99,100分没必要写 3)实习经历这块要有突出的不是劳动性质的亮点,自己设计的什么方案,什么自动化?什么提效工具?不是一些边角料,人云亦云的东西,没吸引力 4) 校园经历纯没用 5)尽量少写减分项
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务