61. Rotate List
文章目录
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.
** 解题思路 **
用快慢指针,分三步来做。第一步用fast 指针算出链表长度;第二步用slow 指针定位要旋转的位置;第三步作旋转。
Since n may be a large number compared to the length of list. So we need to know the length of linked list.After that, move the list after the (l-k%l )th node to the front to finish the rotation.
Ex: {1,2,3} k=2 Move the list after the 1st node to the front
Ex: {1,2,3} k=5, In this case Move the list after (3-5%3=1)st node to the front.
So the code has three parts.
(1) Get the length
(2) Move to the (l-k%l)th node
(3)Do the rotation
|
|
文章作者 Hustbill
上次更新 2017-06-18