给定一个链表,旋转链表,将链表每个节点向右移动 k 个位置,其中 k 是非负数。
示例 1:
输入: 1->2->3->4->5->NULL, k = 2
输出: 4->5->1->2->3->NULL
解释:
向右旋转 1 步: 5->1->2->3->4->NULL
向右旋转 2 步: 4->5->1->2->3->NULL
public ListNode rotateRight(ListNode head, int k) {
if(head==null){return head;}
ListNode fast=head;
ListNode slow=head;
int len=1;
while (fast.next!=null){
len++;
fast=fast.next;
}
//形成闭环
fast.next=head;
//计算慢指针步数
int step=len-k%len;
//慢指针走完
for(int i=0;i<step-1;i++){
slow=slow.next;
}
//尾结点为慢指针后一个节点
ListNode temp=slow.next;
//断开后一节点指针
slow.next=null;
return temp;
}