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

二叉搜索树与双向链表

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

非递归:

struct TreeNode {
	int val;
	struct TreeNode *left;
	struct TreeNode *right;
	TreeNode(int x) :
			val(x), left(NULL), right(NULL) {
	}
};*/
class Solution {
public:
    TreeNode *head;
    TreeNode *pre;
    TreeNode* Convert(TreeNode* pRootOfTree) {
        if(!pRootOfTree)
            return NULL;
        stack<TreeNode *>s;
        while(pRootOfTree||!s.empty()){
            while(pRootOfTree){
                s.push(pRootOfTree);
                pRootOfTree=pRootOfTree->left;
            }
            pRootOfTree=s.top();
            s.pop();
            if(!pre)
                pre=head=pRootOfTree;
            else {
                pre->right=pRootOfTree;
                pRootOfTree->left=pre;
                pre=pRootOfTree;
            }
            pRootOfTree=pRootOfTree->right;
        }
        return head;
    }
};
全部评论

相关推荐

12-13 14:51
已编辑
井冈山大学 算法工程师
龙虾x:算法比你强的没有你美,比你美的…..算了已经没有比你美的了
工作两年想退休了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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