【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
目录
相关文章
|
6天前
【力扣】-- 移除链表元素
【力扣】-- 移除链表元素
16 1
|
13天前
Leetcode第21题(合并两个有序链表)
这篇文章介绍了如何使用非递归和递归方法解决LeetCode第21题,即合并两个有序链表的问题。
34 0
Leetcode第21题(合并两个有序链表)
|
28天前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
28天前
|
数据采集 负载均衡 安全
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
本文提供了多个多线程编程问题的解决方案,包括设计有限阻塞队列、多线程网页爬虫、红绿灯路口等,每个问题都给出了至少一种实现方法,涵盖了互斥锁、条件变量、信号量等线程同步机制的使用。
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
|
9天前
|
搜索推荐 Python
Leecode 101刷题笔记之第五章:和你一起你轻松刷题(Python)
这篇文章是关于LeetCode第101章的刷题笔记,涵盖了多种排序算法的Python实现和两个中等难度的编程练习题的解法。
15 3
|
13天前
LeetCode第二十四题(两两交换链表中的节点)
这篇文章介绍了LeetCode第24题的解法,即如何通过使用三个指针(preNode, curNode, curNextNode)来两两交换链表中的节点,并提供了详细的代码实现。
12 0
LeetCode第二十四题(两两交换链表中的节点)
|
13天前
Leetcode第十九题(删除链表的倒数第N个节点)
LeetCode第19题要求删除链表的倒数第N个节点,可以通过快慢指针法在一次遍历中实现。
32 0
Leetcode第十九题(删除链表的倒数第N个节点)
|
9天前
|
算法 C++ Python
Leecode 101刷题笔记之第四章:和你一起你轻松刷题(Python)
这篇博客是关于LeetCode上使用Python语言解决二分查找问题的刷题笔记,涵盖了从基础到进阶难度的多个题目及其解法。
12 0
|
9天前
|
算法 C++ Python
Leecode 101刷题笔记之第三章:和你一起你轻松刷题(Python)
本文是关于LeetCode算法题的刷题笔记,主要介绍了使用双指针技术解决的一系列算法问题,包括Two Sum II、Merge Sorted Array、Linked List Cycle II等,并提供了详细的题解和Python代码实现。
11 0
|
9天前
|
算法 C++ 索引
Leecode 101刷题笔记之第二章:和你一起你轻松刷题(Python)
本文是关于LeetCode 101刷题笔记的第二章,主要介绍了使用Python解决贪心算法题目的方法和实例。
7 0