• 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 * 10^9

    代码

    1. /**
    2. * Definition for singly-linked list.
    3. * struct ListNode {
    4. * int val;
    5. * ListNode *next;
    6. * ListNode() : val(0), next(nullptr) {}
    7. * ListNode(int x) : val(x), next(nullptr) {}
    8. * ListNode(int x, ListNode *next) : val(x), next(next) {}
    9. * };
    10. */
    11. class Solution {
    12. public:
    13. ListNode* rotateRight(ListNode* head, int k) {
    14. // 如果 k 为 0 或者链表为空或者链表只有一个节点,则无需旋转
    15. if (k == 0 || head == nullptr || head->next == nullptr)
    16. return head;
    17. // 计算链表的长度
    18. ListNode *p = head;
    19. int n = 1;
    20. while (p->next) {
    21. n++;
    22. p = p->next;
    23. }
    24. // 计算实际需要旋转的节点数
    25. k = k % n;
    26. if (k == 0) return head;
    27. // 将链表首尾相连
    28. p->next = head;
    29. // 找到新的尾节点位置,新的尾节点是从头节点开始的第 (n - k) 个节点
    30. for (int i = 0; i < n - k; i++) {
    31. p = p->next;
    32. }
    33. // 新的头节点是新的尾节点的下一个节点
    34. ListNode *newHead = p->next;
    35. // 断开链表,使其成为非循环链表
    36. p->next = nullptr;
    37. return newHead;
    38. }
    39. };

     

  • 相关阅读:
    【MQTT基础篇(四)】ESP8266连接MQTT服务端
    arthars在线诊断
    企业寄件面单隐私保护
    Spring整合RabbitMQ
    Day799.优化垃圾回收机制 -Java 性能调优实战
    KNN算法与SVM支持向量机
    【计组】总线
    快速了解 MongoDB
    工作小记系列2:Kubevirt简介
    【知识网络分析】 一模网络(one node)
  • 原文地址:https://blog.csdn.net/qq_53201790/article/details/139849324