LeetCode 61. 旋转链表

题目链接:https://leetcode-cn.com/problems/rotate-list/

给定一个链表,旋转链表,将链表每个节点向右移动 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

 1 /**
 2  * Definition for singly-linked list.
 3  * struct ListNode {
 4  *     int val;
 5  *     struct ListNode *next;
 6  * };
 7  */
 8 
 9 struct ListNode* rotateRight(struct ListNode* head, int k){
10     if(head==NULL||head->next==NULL) return head;
11     struct ListNode *q=head,*pre;
12     int len=0;
13     while(q){
14         pre=q;
15         q=q->next;
16         len++;
17     }
18     k%=len;
19     pre->next=head;
20     q=head;
21     k=len-k;
22     while(k--){
23         q=q->next;
24         pre=pre->next;
25     }
26     pre->next=NULL;
27     return q;
28 }

 

posted @ 2020-03-03 16:21  wydxry  阅读(202)  评论(0编辑  收藏  举报
Live2D