今天面试让做重排列表,却出现了这样的情况,我死活没想通。

题目如下:

给定一个单链表 L 的头节点 head ,单链表 L 表示为:
L0 → L1 → … → Ln - 1 → Ln
请将其重新排列后变为:
L0 → Ln → L1 → Ln - 1 → L2 → Ln - 2 → …
不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。

class Solution {
public:
    void reorderList(ListNode* head) {
        if (head == nullptr) {
            return;
        }
        ListNode* slow = head;
        ListNode* fast = head;
        while (fast->next != nullptr && fast->next->next != nullptr) {
            slow = slow->next;
            fast = fast->next->next;
        }

        ListNode* mid = slow -> next;
        slow -> next = nullptr;
//cout val;
//cout << endl;

        mid = reverseList(mid);
        mergeList(head, mid);
    }
    ListNode* reverseList(ListNode* head) {
        ListNode* prev = nullptr;
        ListNode* curr = head;
        ListNode* tmp;
        while (curr != nullptr) {
            tmp = curr->next;
            curr->next = prev;
            prev = curr;
            curr = tmp;
        }
        return prev;
    }
    void mergeList(ListNode* l1, ListNode* l2) {
        ListNode* tmp;
        while (l1&& l2) {
            tmp = l1->next;
            l1->next = l2;
            l1 = tmp;

            tmp = l2->next;

            l2->next = l1;
            l2 = tmp;
        }
    }
};

line 16

  1. 在注释的地方加cout val;是正确的结果。
  2. 加cout << endl; 报错栈溢出。
  3. 不加答案结果错误。

我是真没想通,有没有大佬指导一下?

#百度面试##面试##算法题#
全部评论
同学同花顺尝试一下吗,面试简单不造火箭,可保姆式全程跟进度,我帖子有内推
点赞 回复 分享
发布于 2022-09-24 18:43 浙江

相关推荐

点赞 评论 收藏
分享
好兄弟们,不愁找不到工作了,东哥还有10万骑手HC待发&nbsp;还有五险一金,话不多说我要去投递了
婉拒腾讯保洁岗:都让让,鄙人骑电动车贼溜,ssp骑手offer应该有我一份吧?在坐的谁赞同,谁反对?查看图片
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务