首页 > 其他 > 详细

Flatten Binary Tree to Linked List

时间:2021-04-10 00:49:32      阅读:29      评论:0      收藏:0      [点我收藏+]

技术分享图片

 

 二叉树先序遍历排序之后再放入右子树即可

class Solution {
public:
    void flatten(TreeNode* root) {
        vector<TreeNode*> l;
        preorderTraversal(root, l);
        int n = l.size();
        for (int i = 1; i < n; i++) {
            TreeNode *prev = l.at(i - 1), *curr = l.at(i);
            prev->left = nullptr;
            prev->right = curr;
        }
    }

    void preorderTraversal(TreeNode* root, vector<TreeNode*> &l) {
        if (root != NULL) {
            l.push_back(root);
            preorderTraversal(root->left, l);
            preorderTraversal(root->right, l);
        }
    }
};

  

Flatten Binary Tree to Linked List

原文:https://www.cnblogs.com/zhangdalao/p/14638578.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!