#填充每个节点指向最右节点的next指针#基于vector

填充每个节点指向最右节点的next指针

https://www.nowcoder.com/practice/fdbd05d647084fcf9be78444e231998b

/**
 * Definition for binary tree with next pointer.
 * struct TreeLinkNode {
 *  int val;
 *  TreeLinkNode *left, *right, *next;
 *  TreeLinkNode(int x) : val(x), left(NULL), right(NULL), next(NULL) {}
 * };
 */
class Solution {
  public:
    void connect(TreeLinkNode* root) {
        if (root == nullptr) return;

        vector<TreeLinkNode*> arr;
        arr.insert(arr.begin(), root);

        while (!arr.empty()) {
            int n = arr.size();
            for (int i = 0; i < n - 1; i++) {
                arr[i]->next = arr[i + 1];
            }
            arr[n - 1]->next = nullptr;
            for (int i = 0; i < n; i++) {
                TreeLinkNode* node = *arr.begin();
                arr.erase(arr.begin());
                if (node->left) arr.push_back(node->left);
                if (node->right) arr.push_back(node->right);
            }
        }
    }
};

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-01 10:56
点赞 评论 收藏
分享
程序员小白条:你是沟通了900个,不是投了900份简历,你能投900份,意味着对面都要回复你900次,你早就找到实习了,没亮点就是这样的,别局限地区,时间投的也要早,现在都要7月了
点赞 评论 收藏
分享
程序员小白条:找的太晚,别人都是大三实习,然后大四秋招春招的,你大四下了才去实习,晚1年
点赞 评论 收藏
分享
07-02 10:44
门头沟学院 C++
码农索隆:太实诚了,告诉hr,你能实习至少6个月
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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