LC24. 两两交换链表中的节点
给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。
示例 1:

输入:head = [1,2,3,4] 输出:[2,1,4,3]
示例 2:
输入:head = [] 输出:[]
示例 3:
输入:head = [1] 输出:[1]
提示:
- 链表中节点的数目在范围
[0, 100]
内 0 <= Node.val <= 100
模拟
多定义几个节点即可1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16# Definition for singly-linked list.
# class ListNode:
# def __init__(self, val=0, next=None):
# self.val = val
# self.next = next
class Solution:
def swapPairs(self, head: Optional[ListNode]) -> Optional[ListNode]:
h = ListNode(-1,head)
p = h
while p.next and p.next.next:
a,b = p.next,p.next.next
p.next = b
a.next = b.next
b.next = a
p = a
return h.next
递归
把两个节点看成一个整体即可1
2
3
4
5
6
7
8
9
10
11
12
13
14# Definition for singly-linked list.
# class ListNode:
# def __init__(self, val=0, next=None):
# self.val = val
# self.next = next
class Solution:
def swapPairs(self, head: Optional[ListNode]) -> Optional[ListNode]:
if not head or not head.next:
return head
p = head.next
# 从第三个节点开始两两翻转,同时第一个节点连接返回的链表指针
head.next = self.swapPairs(p.next)
p.next = head
return p