今天面试让做重排列表,却出现了这样的情况,我死活没想通。
题目如下:
给定一个单链表 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
- 在注释的地方加cout val;是正确的结果。
- 加cout << endl; 报错栈溢出。
- 不加答案结果错误。
我是真没想通,有没有大佬指导一下?
#百度面试##面试##算法题#