Problem:
Given a list, rotate the list to the right by k places, where k is non-negative.
For example:
Given 1->2->3->4->5->NULL
and k = 2
,
return 4->5->1->2->3->NULL
.
Analysis:
Solutions:
C++:
ListNode* rotateRight(ListNode* head, int k) {
if(head == NULL || head->next == NULL)
return head;
ListNode *p_back = head;
int size = 0;
for(; p_back != NULL; p_back = p_back->next)
++size;
k %= size;
if(k == 0)
return head;
p_back = head;
ListNode *p_front = head;
for(int i = 0; i < k; p_front = p_front->next, ++i) {
if(p_front == NULL)
return NULL;
}
if(p_front == NULL)
return NULL;
for(; p_front->next != NULL; p_front = p_front->next, p_back = p_back->next) {}
ListNode *p_new_head = p_back->next;
p_back->next = NULL;
p_front->next = head;
return p_new_head;
}
Java
:
Python: