LeetCode Java First 400 题解-024

mac2025-01-15  10

Swap Nodes in Pairs    Medium

Given a linked list, swap every two adjacent nodes and return its head.

For example, Given 1->2->3->4, you should return the list as 2->1->4->3.

Your algorithm should use only constant space. You may not modify the values in the list, only nodes itself can be changed.

public ListNode swapPairs(ListNode head) {     ListNode p = head;     if (p == null || p.next == null)         return head;     ListNode newHead = p.next;     p.next = p.next.next;     newHead.next = p;     p = newHead.next.next;     newHead.next.next = swapPairs(p);     return newHead; } 思路:递归,每次Swap两个,然后指向下一部分,最终返回当前部分的头给上一部分的尾。
最新回复(0)