leetcode Reorder List

题意:

Given a singly linked list LL0L1→…→Ln-1Ln,
reorder it to: L0LnL1Ln-1L2Ln-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}.

思路:1.先用快慢指针找到链表的一半,

  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;
        }
        
    }
};


你可能感兴趣的:(LeetCode,C++,linklist,reverse)