Leetcode 24.两两交换链表中的节点
1 题目描述(Leetcode题目链接)
给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。
给定 1->2->3->4, 你应该返回 2->1->4->3.
2 题解
可以使用前后两指针,同时移动,交换指针所指位置的节点。
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution:
def swapPairs(self, head: ListNode) -> ListNode:
if not head:
return None
New_head = ListNode(0)
New_head.next = head
front = head.next
behind = New_head
while front:
behind.next.next = front.next
front.next = behind.next
behind.next = front
if not front.next.next:
return New_head.next
front = front.next.next.next
behind = behind.next.next
return New_head.next