LCR 026. 重排链表
中等
128
相关企业
给定一个单链表 L 的头节点 head ,单链表 L 表示为:
L0 → L1 → … → Ln-1 → Ln
请将其重新排列后变为:
L0 → Ln → L1 → Ln-1 → L2 → Ln-2 → …
不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。
示例 1:
输入: head = [1,2,3,4]
输出: [1,4,2,3]
示例 2:
输入: head = [1,2,3,4,5]
输出: [1,5,2,4,3]
提示:
链表的长度范围为 [1, 5 * 104]
1 <= node.val <= 1000
题解
相当于把链表的后面半段翻转后,和前面半段交替连接。
于是需要利用快慢指针找到中间的节点,然后再写个反转。
AC代码
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode() : val(0), next(nullptr) {}
* ListNode(int x) : val(x), next(nullptr) {}
* ListNode(int x, ListNode *next) : val(x), next(next) {}
* };
*/
class Solution {
public:
void reorderList(ListNode* head)
{
if(head->next==NULL)return;
ListNode* H = new ListNode(0);
H->next = head;
ListNode * slow;
ListNode * fast;
ListNode * cur;
slow = head;
fast = head;
while(slow!=NULL&&fast!=NULL)
{
cur = slow;
slow = slow->next;
fast = fast->next;
if(fast!=NULL)
{
fast = fast->next;
}
}
cur->next = NULL;
//cout<<cur->val<<endl;
//翻转slow开始的节点
ListNode * nex = slow->next;
ListNode * last = slow;
last->next=NULL;
while(nex!=NULL)
{
slow = nex;
nex = nex->next;
slow->next = last;
last = slow;
}
ListNode *p1 = H->next;
ListNode *p2 = slow;
ListNode *p = H;
while(p1!=NULL&&p2!=NULL)
{
//cout<<p1->val<<" "<<p2->val<<endl;
p->next = p1;
p = p->next;
p1 = p1->next;
p->next = p2;
p = p->next;
p2 = p2->next;
}
while(p1!=NULL)
{
p->next = p1;
p1 = p1->next;
}
head = H->next;
}
};