Skip to content

Latest commit

 

History

History
54 lines (51 loc) · 1.22 KB

rotated_list.md

File metadata and controls

54 lines (51 loc) · 1.22 KB

rotated list

problem

Given a linked list, rotate the list to the right by k places, where k is non-negative.

Example 1:

Input: 1->2->3->4->5->NULL, k = 2 Output: 4->5->1->2->3->NULL Explanation: rotate 1 steps to the right: 5->1->2->3->4->NULL rotate 2 steps to the right: 4->5->1->2->3->NULL Example 2:

Input: 0->1->2->NULL, k = 4 Output: 2->0->1->NULL Explanation: rotate 1 steps to the right: 2->0->1->NULL rotate 2 steps to the right: 1->2->0->NULL rotate 3 steps to the right: 0->1->2->NULL rotate 4 steps to the right: 2->0->1->NULL

代码实现

/**
* Definition for singly-linked list.
* struct ListNode {
*     int val;
*     ListNode *next;
*     ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode *rotateRight(ListNode *head, int k) 
    {
       if(head == NULL || head->next == NULL||k==0) return head;
       ListNode* node = head;
       int size =1; 
       while(node->next != NULL)
       {
           size++;
           node = node->next;
       }
       node->next=head;
       k = k%size;
       while(--size >= k)
       {
           node=node->next;
       }
       ListNode* first = node->next;
       node->next=NULL;   
       return first;
   }
};