链表-25.k个一组翻转链表-力扣(LeetCode)

一、题目解析

1、每k个一组进行翻转

2、不允许单纯交换节点内部的值

二、算法原理

解法:模拟

1、遍历链表得到总节点数n,n/=k,得到需要翻转的组数n

利用cur遍历链表,若cur不为空,则n++,cur=cur->next

2、重复n次,长度为k的链表逆序,使用头插法

我们tmp记录每组第一个插入的节点,为了便于下组头插

3、剩下的直接链接到后面,释放哨兵位头结点

三、代码示例

cpp 复制代码
class Solution {
public:
    ListNode* reverseKGroup(ListNode* head, int k)
    {
        //先求需要翻转的组数n
        int n  = 0;
        ListNode* cur = head;
        while(cur)
        {
            n++;
            cur = cur->next;
        }
        n/=k;
        ListNode* newhead = new ListNode(0);
        cur = head;
        ListNode* tmp = nullptr,*prev = newhead,*next = nullptr;
        //重复n次长度为k的链表翻转
        while(n--)
        {
            tmp = cur;
            for(int i = k;i>0;i--)
            {
                if(cur)
                    next = cur->next;
                if(cur)
                    cur->next = prev->next;
                prev->next = cur;
                cur = next;
            }
            prev = tmp;
        }
        //链接剩下的节点
        prev->next = cur;
        cur = newhead->next;
        //释放哨兵位头结点
        delete newhead;
        return cur;
    }
};

看到最后,如果对您有所帮助,还请点赞、收藏和关注支持一波,我们下期再见!

相关推荐
阿昭L1 小时前
堆结构与堆排序
数据结构·算法
2501_941805312 小时前
智慧零售平台中的多语言语法引擎与实时推荐系统实践
leetcode
CoderYanger9 小时前
优选算法-栈:67.基本计算器Ⅱ
java·开发语言·算法·leetcode·职场和发展·1024程序员节
夏鹏今天学习了吗9 小时前
【LeetCode热题100(72/100)】前 K 个高频元素
leetcode
.YM.Z10 小时前
【数据结构】:排序(一)
数据结构·算法·排序算法
墨染点香11 小时前
LeetCode 刷题【172. 阶乘后的零】
算法·leetcode·职场和发展
做怪小疯子11 小时前
LeetCode 热题 100——链表——反转链表
算法·leetcode·链表
做怪小疯子13 小时前
LeetCode 热题 100——矩阵——旋转图像
算法·leetcode·矩阵
sin_hielo14 小时前
leetcode 2435
数据结构·算法·leetcode
crescent_悦14 小时前
PTA L1-020 帅到没朋友 C++
数据结构·c++·算法