【算法专题--链表】K个一组翻转链表 -- 高频面试题(图文详解,小白一看就懂!!!)

目录

一、前言

二、题目描述

三、解题方法

[⭐双指针 -- 采用哨兵位头节点](#⭐双指针 -- 采用哨兵位头节点)

[🥝 什么是哨兵位头节点?](#🥝 什么是哨兵位头节点?)

[🍍 案例图解](#🍍 案例图解)

四、总结与提炼

五、共勉


一、前言

**K个一组翻转链表这道题,可以说是--链表专题--,最经典的一道题,也是在面试中频率最高的一道题目,通常在面试中,面试官可能会从多个方面考察这道题目,所以大家需要对这道题目非常熟悉哦!!
本片博客就来详细的讲讲解一下
K个一组翻转链表****的实现方法,**让我们的面试变的更加顺利!!!

二、题目描述

题目连接:25. K 个一组翻转链表 - 力扣(LeetCode)

三、解题方法

⭐双指针 -- 采用哨兵位头节点

🥝 什么是哨兵位头节点?

首先,先来了解一下什么是 哨兵位---头节点

  • 它是一个附加的链表结点,该 结点 作为 第一个节点,它的数据域不存储任何东西,只是为了操作的方便而引入的。
  • 也就是说,如果一个链表有哨兵节点的话,那么链表表的第一个元素应该是链表的第二个节点。

哨兵位 --- 头节点的作用:

  • 比如向链表中插入一个节点,对于没有哨兵位单链表当待插入的节点为链表的第一个节点,由于没有前驱,需要进行特殊处理,从而代码的复杂性增加。
  • 如果有哨兵位头节点,则第一个节点的处理方式与其它节点相同,可以统一进行处理

🍍 解题思路

根据题目要求,我们需要将链表中每 k个节点翻转。我们先统计链表中的节点数 ,然后每 k 个节点作为一组,在这一组中进行链表翻转,翻转后我们利用一个节点p0 将已经翻转的节点和接下来将要翻转的节点沟通起来。

🍍 案例图解

链表:****【1,2,3,4,5】

  • 创建 哨兵位头节点 和 双指针,开始遍历整个链表,并统计链表的节点个数 count = 5
  • 外循环1 中,我们可以根据 反转链表 中讲过的三指针法,先将第一组的链表翻转,接着 更新指针p0 ,指向第二组链表的头节点,同理可以得到 外循环 2 的结果

复杂度分析 :

**时间复杂度:**O ( n ),n 为链表的节点个数

**空间复杂度:**O ( 1 )


代码:

复制代码
class Solution {
public:
    ListNode* reverseKGroup(ListNode* head, int k) 
    {
        // 反转链表(三指针) + 哨兵位

        // 创建一个哨兵位 初始化为 -1,连接到 head 上
        ListNode* pre_head = new ListNode(-1,head);
        ListNode* p0  = pre_head;  // 用于连接反转后的链表

        // 统计链表有多少个节点
        int count = 0;
        ListNode* cur = head;
        while(cur)
        {
            cur = cur->next;
            count++;
        }

        // 开始进行分组反转  --     三指针法
        ListNode* pre = nullptr;
        cur = head;
        for(int n = count ; n>=k ; n = n-k)
        {
            // 反转局部链表,反转 k 个节点
            for(int i = 0; i < k ; i++)
            {
                ListNode* nextnode = cur->next;
                cur->next = pre;
                pre = cur;
                cur = nextnode;
            }
            // 将反转的节点 和 要反转的的节点沟通起来
            ListNode* next = p0->next;
            p0->next->next = cur;
            p0->next = pre;
            p0 = next;  
        }
        // 返回哨兵位的 下一个节点
        return pre_head->next;
    }
};

四、总结与提炼

最后我们来总结一下本文所介绍的内容,本文讲解来一道力扣中有关 K个一组翻转链表的题目,这道题目是校招笔试面试中有关链表章节非常高频的一道题目, 大家下去一定要自己再画画图,分析一下,把这段代码逻辑自己实现一遍,才能更好地掌握

五、共勉

以下就是我对 K个一组翻转链表 的理解,如果有不懂和发现问题的小伙伴,请在评论区说出来哦,同时我还会继续更新对 链表专题 的理解,请持续关注我哦!!!

相关推荐
2401_831824962 小时前
基于C++的区块链实现
开发语言·c++·算法
We་ct2 小时前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
愣头不青2 小时前
238.除了自身以外数组的乘积
数据结构·算法
汉克老师3 小时前
GESP5级C++考试语法知识(六、链表(一)单链表)
c++·链表·单链表·快慢指针·进阶·gesp5级·gesp五级
人工智能AI酱3 小时前
【AI深究】逻辑回归(Logistic Regression)全网最详细全流程详解与案例(附大量Python代码演示)| 数学原理、案例流程、代码演示及结果解读 | 决策边界、正则化、优缺点及工程建议
人工智能·python·算法·机器学习·ai·逻辑回归·正则化
WangLanguager3 小时前
逻辑回归(Logistic Regression)的详细介绍及Python代码示例
python·算法·逻辑回归
m0_518019483 小时前
C++与机器学习框架
开发语言·c++·算法
一段佳话^cyx3 小时前
详解逻辑回归(Logistic Regression):原理、推导、实现与实战
大数据·算法·机器学习·逻辑回归
qq_417695053 小时前
C++中的代理模式高级应用
开发语言·c++·算法
xiaoye-duck3 小时前
《算法题讲解指南:动态规划算法--路径问题》--5.不同路径,6.不同路径II
c++·算法·动态规划