LeetCode 刷题【61. 旋转链表】

61. 旋转链表

自己做

解:截取拼接

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* rotateRight(ListNode* head, int k) {
        ListNode *p = head, *q = head, *r = head;
        int l = 0;                          //链表长

        if(head == nullptr || head->next == nullptr)                 //没有移动空间
            return head;

        while(p != nullptr){                //计算链表长
            p = p -> next;
            l++;
        }
        p = head;                           //归位p

        //调整k
        k %= l;

        if(k == 0)                          //为0则不移动
            return head;

        for(int i = 0; i < k; i++)          //q、r包含k个元素
            r = r->next;

        if(k > 0)
            q = p->next;

        while(r->next != nullptr){        //使r指向尾部
            p = q;
            r = r->next;
            q = q->next;
        }

        p->next = nullptr;
        r->next = head;

        return q;

    }
};
相关推荐
ArturiaZ2 分钟前
【day60】
算法·深度优先·图论
2401_8512729913 分钟前
自定义内存检测工具
开发语言·c++·算法
☆56634 分钟前
C++中的命令模式
开发语言·c++·算法
仰泳的熊猫35 分钟前
题目2577:蓝桥杯2020年第十一届省赛真题-走方格
数据结构·c++·算法·蓝桥杯
CoovallyAIHub1 小时前
Pipecat:构建实时语音 AI Agent 的开源编排框架,500ms 级端到端延迟
深度学习·算法·计算机视觉
灰色小旋风1 小时前
力扣13 罗马数字转整数
数据结构·c++·算法·leetcode
2301_810160951 小时前
C++与物联网开发
开发语言·c++·算法
cm6543201 小时前
基于C++的操作系统开发
开发语言·c++·算法
ArturiaZ1 小时前
【day57】
开发语言·c++·算法
CoovallyAIHub1 小时前
Energies | 8版YOLO对8版Transformer实测光伏缺陷检测,RF-DETR-Small综合胜出
深度学习·算法·计算机视觉