题目
给定一个链表,旋转链表,将链表每个节点向右移动 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
复制代码示例 2:
输入: 0->1->2->NULL, k = 4
输出: 2->0->1->NULL
解释:
向右旋转 1 步: 2->0->1->NULL
向右旋转 2 步: 1->2->0->NULL
向右旋转 3 步: 0->1->2->NULL
向右旋转 4 步: 2->0->1->NULL
思想
指针交换,这个题目先让链表连成一个环,然后再切开就可以完成了。在count-k处切开
class Solution(object):
def rotateRight(self, head, k):
"""
:type head: ListNode
:type k: int
:rtype: ListNode
"""
if head is None or head.next is None:
return head
# 链表的节点个数
count = 1
cur = head
while cur.next:
count += 1
cur = cur.next
# 如果恰好走了一个环,就直接返回
k = k % count
if k == 0:
return head
cur.next = head
dummy = ListNode(-1)
dummy.next = head
prev = dummy
# 需要走count-k个,然后把链表切断
for _ in range(count - k):
prev = prev.next
# 重新组成新的链表
cur = prev.next
new_head = cur
prev.next = None
return new_head