leetcode 61: 旋转链表
给你一个链表的头节点 head
,旋转链表,将链表每个节点向右移动 k
个位置。
示例 1:
输入:head = [1,2,3,4,5], k = 2 输出:[4,5,1,2,3]
示例 2:
输入:head = [0,1,2], k = 4 输出:[2,0,1]
提示:
-
链表中节点的数目在范围
[0, 500]
内 -
-100 <= Node.val <= 100
-
0 <= k <= 2 * 109
思路:使用双指针的思想
-
判断链表的长度。
-
因为k可能大于链表的长度,当k等于链表的长度时,实际上将链表旋转一圈并没有改变链表,所以需要求出k对链表长度的余数。
-
当k为0时,说明不需要旋转。
-
不为0时,使用双指针,通过代码中示例说明。
public ListNode rotateRight(ListNode head, int k) { if(head == null || head.next == null){ return head; } ListNode start,end,newHead; ListNode p = head; int length = 0; //先统计链表的长度 while(p!=null){ p=p.next; length++; } //当K等于length时,刚好旋转一圈 k %= length; if(k==0){// 等于0时 不需要旋转 return head; } /** * 示例1: 1->2->3->4->5 向右旋转2位变成 4->5->1->2->3 * * 我们需要找到3和5的位置 将3和4断开 5指向1 * 4就是我们要找的旋转后的头节点 * * 下面用示例1说明 */ start = head; //start = 1 end = head; //end =1 for(int i = 0 ; i < k;i++){ end = end.next; }//end = 3 while(end.next!=null){ start = start.next; end = end.next; }//start = 3 end 5 newHead = start.next; start.next = null; end.next = head; return newHead; }