【牛客刷题】反转固定区间链表、每k个节点一组反转

链表内指定区间反转_牛客题霸_牛客网

cpp 复制代码
    ListNode* reverseList(ListNode* head, ListNode* tail) {
        ListNode* pre = nullptr;
        ListNode* cur = head;
        while (cur != tail) { 最后cur就是tail
            ListNode* temp = cur->next;
            cur->next = pre;
            pre = cur;
            cur = temp;
        }
        return pre;
    }
    
    ListNode* reverseBetween(ListNode* head, int m, int n) {
        ListNode* dummyNode = new ListNode(0);
        dummyNode->next = head;
        ListNode* pre = dummyNode;
        for (int i = 1; i < m; i++) {
            pre = pre->next;
        }
        ListNode* start = pre->next;
        ListNode* end = pre->next;
        for (int i = m; i <= n; i++) {
            end = end->next;
        }
        
        pre->next = reverseList(start, end);//执行这个函数以后start变成传过去的链表的尾节点,所以直接连接start和end就行
        start->next = end;
        return dummyNode->next;
    }

链表中的节点每k个一组翻转_牛客题霸_牛客网

cpp 复制代码
    ListNode* reverseList(ListNode* head, ListNode* tail) {
        ListNode* pre = nullptr;
        ListNode* cur = head;
        while (cur != tail) {
            ListNode* temp = cur->next;
            cur->next = pre;
            pre = cur;
            cur = temp;
        }
        return pre;
    }

    ListNode* reverseKGroup(ListNode* head, int k) {
        // write code here
        if (k == 1 || head->next == nullptr || head == nullptr) return head;

        ListNode* dummy = new ListNode(0);
        dummy->next = head;
        ListNode* pre = dummy;
        ListNode* start = pre->next;
        ListNode* end = pre;
        while (end->next != nullptr && end != nullptr) {
            start = pre->next;
            end = pre;
            int i;
            for (i = 0; i <= k; i++) {
                if (end->next) end = end->next;
                else {
                    end = nullptr;
                    break;
                }
            }
            if (i < k) break;
            else {
                pre->next = reverseList(start, end);
                start->next = end;
                pre = start;
            }
        }
        return dummy->next;
    }
相关推荐
程序猿麦小七8 分钟前
今天给在家介绍一篇基于jsp的旅游网站设计与实现
java·源码·旅游·景区·酒店
张某布响丸辣21 分钟前
SQL中的时间类型:深入解析与应用
java·数据库·sql·mysql·oracle
喜欢打篮球的普通人26 分钟前
rust模式和匹配
java·算法·rust
java小吕布40 分钟前
Java中的排序算法:探索与比较
java·后端·算法·排序算法
慢生活的人。1 小时前
SpringSecurity+jwt+captcha登录认证授权总结
java·认证·rbac·权限·验证
win x1 小时前
链表(Linkedlist)
数据结构·链表
杜若南星1 小时前
保研考研机试攻略(满分篇):第二章——满分之路上(1)
数据结构·c++·经验分享·笔记·考研·算法·贪心算法
向阳12181 小时前
LeetCode40:组合总和II
java·算法·leetcode
云空1 小时前
《InsCode AI IDE:编程新时代的引领者》
java·javascript·c++·ide·人工智能·python·php
慧都小妮子1 小时前
Spire.PDF for .NET【页面设置】演示:复制 PDF 文档中的页面
java·pdf·.net