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

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

相关推荐
梵刹古音1 分钟前
【C语言】 指针与数据结构操作
c语言·数据结构·算法
VT.馒头6 分钟前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
爱敲代码的TOM1 小时前
数据结构总结
数据结构
Charlie_lll2 小时前
力扣解题-移动零
后端·算法·leetcode
iAkuya3 小时前
(leetcode)力扣100 62N皇后问题 (普通回溯(使用set存储),位运算回溯)
算法·leetcode·职场和发展
皮皮哎哟3 小时前
数据结构:嵌入式常用排序与查找算法精讲
数据结构·算法·排序算法·二分查找·快速排序
堕2744 小时前
java数据结构当中的《排序》(一 )
java·数据结构·排序算法
2302_813806224 小时前
【嵌入式修炼:数据结构篇】——数据结构总结
数据结构
Wei&Yan5 小时前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
long3165 小时前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法