说在前面

今天博主给大家带来的是力扣上的一道链表OJ,完成这道题后,博主感觉这题覆盖了很多链表的解题思想,另外,这道题对指针的控制也是比较高的。在这里博主将这道好题分享给大家!
另外,对于链表等数据结构还没有很熟悉的伙伴,可以通过传送门食用!


博主给大家的话

那么这里博主先安利一下一些干货满满的专栏啦!

数据结构专栏:手撕数据结构 这里包含了博主很多的数据结构学习上的总结,每一篇都是超级用心编写的,有兴趣的伙伴们都支持一下吧!
算法专栏:算法 这里可以说是博主的刷题历程,里面总结了一些经典的力扣上的题目,和算法实现的总结,对考试和竞赛都是很有帮助的!
力扣刷题专栏:跟着博主刷Leetcode 想要冲击ACM、蓝桥杯或者大学生程序设计竞赛的伙伴,这里面都是博主的刷题记录,希望对你们有帮助!
C的深度解剖专栏:C语言的深度解剖 想要深度学习C语言里面所蕴含的各种智慧,各种功能的底层实现的初学者们,相信这个专栏对你们会有帮助的!

题目描述

解题思路

思路:
首先我们想到的大致思路是,先定义两个指针fastslowfast往前走,走几步之后,我们反转fastslow之间的链表,再拼接起来。

又因为现在题目所给链表是不带头的,slow指向的节点,是我们要反转的链表的头节点(如果需要要反转的话),而fast所指向的节点是要反转的链表的尾节点的后一个节点。
就拿例子1来举例子,我们的指针位置应该是这样的:

  • 那我们该如何去找这个反转区间呢,这个很简单,第一次fast走一步,第二次走两步,第三次走三步…,当fast走的步数是偶数次时,反转。

如果要反转一个区间的链表,光有这两个指针是不够的。
假设我们刚才要反转[2,6]那个区间的链表,我们必须先让6next置空,然后反转2开头的链表,再链接到5上,然后再把尾链接到3上,所以我们还需要两个指针,slow_prevfast_prev,分别指向fast的前一个节点和slow的前一个节点。


完整的实现代码

// 2074. 反转偶数长度组的节点
class Solution {
private:
struct ListNode* reverseList(struct ListNode* head) {
struct ListNode* newhead = NULL;
if (head == NULL) {
return head;
}
struct ListNode* cur = head;
struct ListNode* next = head->next;
while (cur != NULL) {
cur->next = newhead;
newhead = cur;
cur = next;
if (cur != NULL) {
next = cur->next;
}
}
return newhead;
}
public:
ListNode* reverseEvenLengthGroups(ListNode* head) {
if (head == NULL || head->next == NULL)return head;
ListNode* slow_prev = head;
ListNode* fast_prev = head;
ListNode* fast = head;
ListNode* slow = head;
for (int i = 1;; i++) {
int i_tmp = i;
while (i_tmp && fast) {
fast_prev = fast;
fast = fast->next;
i_tmp--;//这个一定要放在里面,否则就减多一次了!
}
if ((i - i_tmp) % 2 == 0) {//有可能最后一个区间走不完,所以只需要看走了多少步
//反转链表
fast_prev->next = NULL;
slow_prev->next = reverseList(slow);
//找尾
while (slow_prev->next) {
slow_prev = slow_prev->next;
}
slow_prev->next = fast;
slow = fast;
fast_prev = slow_prev;
}
else {//不用反转
slow_prev = fast_prev;
slow = fast;
}
if (fast == NULL)break;
}
return head;
}
};

调试代码(编译器调试用)

如果我们在自己写这道题时遇到困难,需要复制到本地IDE上调试,博主把链表弄好了提供给大家,大家直接调试接口就好了!

ListNode* _CreatListNode(int x);
void ListPushBack(ListNode** pphead, int x);
int main() {
//[5,2,6,3,9,1,7,3,8,4]
Solution su;
ListNode* head = NULL;
ListPushBack(&head, 5);
ListPushBack(&head, 2);
ListPushBack(&head, 6);
ListPushBack(&head, 3);
ListPushBack(&head, 9);
ListPushBack(&head, 1);
ListPushBack(&head, 7);
ListPushBack(&head, 3);
ListPushBack(&head, 8);
ListPushBack(&head, 4);
//从这里开始调试
ListNode* ret = su.reverseEvenLengthGroups(head);
return 0;
} ListNode* _CreatListNode(int x) {
ListNode* newNode = (ListNode*)malloc(sizeof(ListNode));
newNode->val = x;
newNode->next = NULL;
return newNode;
} void ListPushBack(ListNode** pphead, int x) {
ListNode* newNode = _CreatListNode(x);
//空链表的情况
if (*pphead == NULL) {
*pphead = newNode;
}
else {
//找尾
ListNode* tail = *pphead;
while (tail->next != NULL) {
tail = tail->next;
}
tail->next = newNode;
}
}

尾声

看到这里,相信你已经学会这道题了,如果你感觉这篇博客对你有帮助的话,不要忘了一键三连哦!

【链表】链表OJ-力扣2074. 反转偶数长度组的节点【超详细的算法解释】的更多相关文章

  1. 力扣 - 92. 反转链表II

    目录 题目 思路1(迭代) 代码 复杂度分析 思路2(递归) 代码 复杂度分析 题目 92. 反转链表 II 思路1(迭代) 将反转链表分成3个部分:前一段未反转的部分.待反转链表部分.后一段未反转部 ...

  2. 【力扣】反转链表I和II(迭代和递归)

    前言 有句话叫做:如果面试官跟你看顺眼的话,就给你出一道反转链表,否则就出一道 hard. 所以反转链表不能不会吧,要不面试官想要你都没有机会了. 206. 反转链表 class Solution { ...

  3. 刷题-力扣-541. 反转字符串 II

    541. 反转字符串 II 题目链接 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/reverse-string-ii 著作权归领扣网络所有. ...

  4. Leetcode(力扣) 整数反转

    Leetcode 7.整数反转 给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转. 示例: 输入: -123 输出: -321 注意: 假设我们的环境只能存储得下 32 位的有符 ...

  5. 力扣541. 反转字符串 II

    原题 1 class Solution: 2 def reverseStr(self, s: str, k: int) -> str: 3 begin,lens,ans = 0,len(s),' ...

  6. 【Warrior刷题笔记】143.重排链表 【线性化 || 双指针+翻转链表+链表合并】详细注释

    题目一 力扣143.重排链表 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/reorder-list/ 1.描述 给定一个单链表L的头节点he ...

  7. 力扣(LeetCode)删除排序链表中的重复元素II 个人题解

    给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出现 的数字. 思路和上一题类似(参考 力扣(LeetCode)删除排序链表中的重复元素 个人题解)) 只不过这里需要用到一个前 ...

  8. 力扣—Reorder List(重排链表)python实现

    题目描述: 中文: 给定一个单链表 L:L0→L1→…→Ln-1→Ln ,将其重新排列后变为: L0→Ln→L1→Ln-1→L2→Ln-2→… 你不能只是单纯的改变节点内部的值,而是需要实际的进行节点 ...

  9. 力扣 ——Linked List Cycle II(环形链表 II) python实现

    题目描述: 中文: 给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始). ...

  10. 力扣——Linked List Cycle(环形链表) python实现

    题目描述: 中文: 给定一个链表,判断链表中是否有环. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始). 如果 pos 是 -1,则在该链表中没有环. ...

随机推荐

  1. Codeforces Round #481 (Div. 3) 经典几道思维题

    A - AAA POJ - 3321 给你一颗树,支持两种操作 1.修改某一节点的权值 2.查询子树的权值(子树中节点的个数) 很显然可以用树状数组/线段树维护 B - BBB CodeForces ...

  2. HDU-3032--Nim or not Nim?(博弈+SG打表)

    题目分析: 这是一个经典的Multi-SG游戏的问题. 相较于普通的Nim游戏,该游戏仅仅是多了拆成两堆这样的一个状态.即多了一个SG(x+y)的过程. 而根据SG定理,SG(x+y)这个游戏的结果可 ...

  3. 成都站|阿里云 Serverless 技术实战营邀你来玩!

    活动简介 "Serverless 技术实战与创新沙龙 " 是一场以 Serverless 为主题的开发者活动,活动受众以关注Serverless 技术的开发者.企业决策人.云原生领 ...

  4. vue监听滚动到底部加载更多

    https://blog.csdn.net/qq_39762109/article/details/89354305 此方法有个bug

  5. java进阶(24)--ArrayList集合、LinkList集合、Vector集合

    一.基础 1.ArrayList集合底层是Object[]数组 2.默认容量10(优先:Add第一个元素,初始化未0,jdk13) 3.构造方法:无参(默认).有参 4.ArrayList集合扩容比例 ...

  6. [转帖]12.24.2 DECIMAL Data Type Characteristics

    https://dev.mysql.com/doc/refman/8.0/en/fixed-point-types.html This section discusses the characteri ...

  7. [转帖] 原来awk真是神器啊

    https://www.cnblogs.com/codelogs/p/16060082.html 简介# 刚开始入门awk时,觉得awk很简单,像是一个玩具,根本无法应用到工作之中,但随着对awk的了 ...

  8. alertmanager远程配置

    用于远程配置alertmanager的rules. 主要步骤为: 通过proxy更新mount的告警规则文件 重启容器 # ./client -h Note: Only for update exis ...

  9. 一文搞懂Go GC演进史,讲的太细致了!

    最近在和 Go就业训练营 的朋友讨论Go GC的问题,发现了刘丹冰老师总结的内容,写的太好了,和大家分享一下. 我们的讨论和思考也整理到这篇文章中了,希望对你有启发. 垃圾回收(Garbage Col ...

  10. echarts去掉y轴线、设置x轴线的颜色、x轴文字颜色

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...