链表-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;
    }
};

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

相关推荐
Paxon Zhang2 小时前
数据结构之**二叉树**超全秘籍宝典2
java·数据结构·算法
一匹电信狗2 小时前
【C++】哈希表详解(开放定址法+哈希桶)
服务器·c++·leetcode·小程序·stl·哈希算法·散列表
迷途之人不知返3 小时前
链表相关的算法题(2)
数据结构·算法·链表
nju_spy3 小时前
力扣每日一题(四)线段树 + 树状数组 + 差分
数据结构·python·算法·leetcode·面试·线段树·笔试
xie0510_3 小时前
排序算法
数据结构·算法·排序算法
黑岚樱梦3 小时前
代码随想录打卡day25:56.合并区间
数据结构·算法
小年糕是糕手4 小时前
【数据结构】常见的排序算法 -- 插入排序
c语言·开发语言·数据结构·学习·算法·leetcode·排序算法
墨染点香4 小时前
LeetCode 刷题【142. 环形链表 II】
算法·leetcode·链表
海琴烟Sunshine4 小时前
leetcode 263. 丑数 python
python·算法·leetcode
User_芊芊君子4 小时前
【LeetCode 经典题解】:队列与栈的双向模拟——从原理到代码详解
linux·redis·leetcode