【Leetcode刷题Python】328. 奇偶链表

简介: 在不使用额外空间的情况下,将链表中的奇数和偶数索引节点重新排序的方法,并提供了相应的Python实现代码。

1 题目

给定单链表的头节点 head ,将所有索引为奇数的节点和索引为偶数的节点分别组合在一起,然后返回重新排序的列表。

第一个节点的索引被认为是 奇数 , 第二个节点的索引为 偶数 ,以此类推。

请注意,偶数组和奇数组内部的相对顺序应该与输入时保持一致。

你必须在 O(1) 的额外空间复杂度和 O(n) 的时间复杂度下解决这个问题。

2 解析

(1)方法一

插入排序的思想,四个指针,

  • prev:奇数的链表插入位置
  • curr,奇数位置
  • mid:偶数位置
  • end:记录奇数位置后续的链表尾巴
    注意:要判断【】、【1】两种类型的链表,是不做处理,直接返回

(2)方法二

插入排序的思想,三个指针,

  • p:奇数的链表插入位置
  • q:偶数位置
  • r:奇数位置
    注意:要判断空的链表不做处理

3 python实现

(1)方法一

def oddEvenList(self, head: Optional[ListNode]) -> Optional[ListNode]:
        # 插入排序的思想,四个指针,prev:奇数的链表插入位置,curr,奇数位置,mid:偶数位置,end:记录奇数位置后续的链表尾巴
        # 注意:3个元素以下,直接返回链表
        if not head or not head.next :
            return head
        prev = head
        mid =head.next
        curr = head.next.next
        while curr :
            # 记录后续节点
            end =curr.next
            # 将奇数节点向前插入
            curr.next = prev.next
            prev.next = curr
            # 链接后续节点,恢复整个完整链表
            mid.next = end
            # 所有指针往后移动
            mid =mid.next
            prev = prev.next
            # 注意:可能没有了后续节点
            if end:
                # curr指针移动两步,跳过偶数节点
                curr = end.next
            else:
                curr = None
        return head

(2)方法二

三个指针,插入排序的思想
def oddEvenList(self, head: Optional[ListNode]) -> Optional[ListNode]:
   if not head:
        return head
    p,q = head,head.next
    while q and q.next:
        r = q.next
        # 将r后续链表连接上
        q.next =r.next
        # 将r节点前插
        r.next = p.next
        p.next = r   
        p = p.next
        q = q.next
    return head
目录
打赏
0
0
0
0
153
分享
相关文章
Python 中链表的个人理解
简介:本文介绍了Python中链表的基本组成及其操作实现。链表由`head`(头节点)、中间节点和`tail`(尾节点)三部分构成,每个节点通过`Node`类定义,包含`value`(值域)和`next`(指针域)。示例代码展示了链表的增删查功能,包括`add`(头部插入)、`append`(尾部插入)、`remove`(删除节点)、`search`(查找节点)及遍历方法。运行结果验证了链表操作的正确性。
Python 实现单向链表,和单向链表的反转
链表是一种数据结构,每个节点存储相邻节点的位置信息。单链表中的节点仅存储下一节点的位置。通过Python实现单链表,定义`ListNode`类并关联节点可创建链表。例如,创建A->B->C的链表后,可通过反转函数`reverse`将链表反转为CBA。代码展示了如何实现和操作单链表。
Python 实现单向链表,和单向链表的反转
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
104 6
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
Python 实现反转、合并链表有啥用?
大家好,我是V哥。本文介绍Python实现反转链表和合并链表的应用场景及代码实现。反转链表适用于时间序列数据展示、回文链表判断等;合并链表则用于大规模数据排序、数据库查询结果集合并等。通过迭代和递归方法实现反转链表,以及合并两个或多个有序链表的算法,帮助开发者解决实际问题。关注V哥,了解更多实用编程技巧。 先赞再看后评论,腰缠万贯财进门。
【刷题记录】移除链表元素
【刷题记录】移除链表元素
|
3月前
|
探索 Python 中链表的实现:从基础到高级
链表是一种由节点组成的基础数据结构,每个节点包含数据和指向下一个节点的引用。本文通过Python类实现单向链表,详细介绍了创建、插入、删除节点等操作,并提供示例代码帮助理解。链表在处理动态数据时具有高效性,适用于大量数据变动的场景。文章为初学者提供了全面的入门指南,助你掌握链表的核心概念与应用。
147 0
280页PDF,全方位评估OpenAI o1,Leetcode刷题准确率竟这么高
【10月更文挑战第24天】近年来,OpenAI的o1模型在大型语言模型(LLMs)中脱颖而出,展现出卓越的推理能力和知识整合能力。基于Transformer架构,o1模型采用了链式思维和强化学习等先进技术,显著提升了其在编程竞赛、医学影像报告生成、数学问题解决、自然语言推理和芯片设计等领域的表现。本文将全面评估o1模型的性能及其对AI研究和应用的潜在影响。
148 1
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
本文提供了多个多线程编程问题的解决方案,包括设计有限阻塞队列、多线程网页爬虫、红绿灯路口等,每个问题都给出了至少一种实现方法,涵盖了互斥锁、条件变量、信号量等线程同步机制的使用。
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
|
8月前
【刷题记录】链表的回文结构
【刷题记录】链表的回文结构
|
8月前
|
【Leetcode刷题Python】50. Pow(x, n)
本文介绍了LeetCode第50题"Pow(x, n)"的解法,题目要求实现计算x的n次幂的函数,文章提供了递归分治法的详细解析和Python实现代码。
63 1
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等