• 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 }
  • 相关阅读:
    登录界面
    动手动脑
    关于二进制
    Java考试
    D
    威尔逊定理 k!%p
    11.46.2020质检
    最长上升序列输出方案
    问题 G: 汽车的最终位置
    奶牛大会(二分)
  • 原文地址:https://www.cnblogs.com/wydxry/p/12402966.html
Copyright © 2020-2023  润新知