题意:
Given a singly linked list L: L0→L1→…→Ln-1→Ln,
reorder it to: L0→Ln→L1→Ln-1→L2→Ln-2→…
You must do this in-place without altering the nodes' values.
For example,
Given {1,2,3,4}
, reorder it to {1,4,2,3}
.
2.将后半部分倒置
3.将后半部分挨个插入前半部分
其中补充一点,对插入数的情况的具体描述分析: 对1->2->3->4 将3插入1后面
p1 =1 p2=2 p3=3
第一步:p2->next = p3->next;
第二步:p3->next = p1->next;
第三步:p1->next = p3;
插入完成。
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
void reorderList(ListNode* head) {
if(head==NULL || head->next==NULL)
return;
ListNode* p1=head, *p2=head->next;
while(p2 && p2->next!=NULL){
p1 = p1->next;
p2 = p2->next->next;
}
//first reverse the latter half 1->2->3->4->5->6 ==> 1->2->3->6->5->4
//这里用2个指针来标识位置,第一个是p1(3),标识其后面不断改变的值6,5,4;
//第二个是p1->next(4),不断将其后面的值往p1后面加入,并用来判断是否转置结束
ListNode* premiddle = p1;
ListNode* precurrent = p1->next;
while(precurrent->next != NULL){
ListNode* current = precurrent->next; //待转置的数5
precurrent->next = current->next;//将4指向5指向的值
current->next = premiddle->next;//将5指向3指向的值
premiddle->next = current;//将3指向当前转置的数5
}
//然后将后半部分插入前半部分
p1=head;//往p1后面插数
p2=premiddle->next;//premiddile后面是待插数
while(p1 != premiddle){
premiddle->next = p2->next;
p2->next = p1->next;
p1->next=p2;
p1=p2->next;
p2=premiddle->next;
}
}
};