1 问题
给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。
示例 1:
输入:head = [1,2,3,4]
输出:[2,1,4,3]
示例 2:
输入:head = []
输出:[]
示例 3:
输入:head = [1]
输出:[1]
答案
自己写的不对,还是没有理解链表
class Solution:def swapPairs(self, head: Optional[ListNode]) -> Optional[ListNode]:n = 0while head:head = head.nextn += 1if n < 2:return headdummy = ListNode(0)dummy.next = headcur = dummyfor _ in range(n//2 + 1):cur.next = cur.next.next.nextcur.next.next = cur.next.next.next.nextreturn dummy
官方解
# 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]:dummy = ListNode(0)dummy.next = headcur = dummywhile cur.next and cur.next.next:a, b = cur.next, cur.next.nextcur.next, a.next = b, b.nextb.next = acur = cur.next.nextreturn dummy.next