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

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

相关推荐
xlp666hub5 小时前
Leetcode 第三题:用C++解决最长连续序列
c++·leetcode
xlp666hub8 小时前
Leetcode第二题:用 C++ 解决字母异位词分组
c++·leetcode
xlp666hub1 天前
Leetcode第一题:用C++解决两数之和问题
c++·leetcode
任沫1 天前
字符串
数据结构·后端
祈安_1 天前
Java实现循环队列、栈实现队列、队列实现栈
java·数据结构·算法
NineData3 天前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
琢磨先生David11 天前
Day1:基础入门·两数之和(LeetCode 1)
数据结构·算法·leetcode
qq_4542450311 天前
基于组件与行为的树状节点系统
数据结构·c#
超级大福宝11 天前
N皇后问题:经典回溯算法的一些分析
数据结构·c++·算法·leetcode
Charlie_lll11 天前
力扣解题-88. 合并两个有序数组
后端·算法·leetcode