[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}.

Solution:

/**
 * 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 *fast = head, *slow = head, *tmp1 = NULL, *tmp2 = NULL, *ansHead = NULL, *ansEnd = NULL;
        while(fast -> next != NULL)
      {
        fast = fast -> next;
        if(fast -> next == NULL)
        {
          //reach the end
          break;
        }
        else
        {
          fast = fast -> next;
          slow = slow -> next;
        }
      } 
        
      ListNode *list2start = slow -> next;
      slow -> next = NULL;
      tmp1 = list2start -> next;
      list2start -> next = NULL;
      while(tmp1 != NULL)
      {
        tmp2 = tmp1 -> next;
        tmp1 -> next = list2start;
        list2start = tmp1;
        tmp1 = tmp2;
      }
      tmp1 = head -> next;
      tmp2 = list2start;
      ansHead = head;
      ansEnd = head;
      while(tmp1 != NULL || tmp2 != NULL)
      {
        if(tmp2 != NULL)
        {
          ansEnd -> next = tmp2;
          tmp2 = tmp2 -> next;
          ansEnd = ansEnd -> next;
        }
        if(tmp1 != NULL)
        {
          ansEnd -> next = tmp1;
          tmp1 = tmp1 ->next;
          ansEnd = ansEnd -> next;
        }
      }
      head = ansHead;
      return;
    }
};
posted @ 2014-04-18 14:37  xchangcheng  阅读(169)  评论(0)    收藏  举报