给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。
示例:
给定 1->2->3->4, 你应该返回 2->1->4->3.
说明:
你的算法只能使用常数的额外空间。
你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。
代码
class Solution {
public ListNode swapPairs(ListNode head) {
ListNode p = new ListNode(Integer.MAX_VALUE);
ListNode ans = p;
p.next = head;
while (p != null) {
ListNode front = p;
ListNode middle = p.next;
if (middle == null) break;
ListNode back = p.next.next;
if (back == null) break;
swap(front, middle, back);
p = p.next;
p = p.next;
}
return ans.next;
}
private void swap(ListNode front, ListNode middle, ListNode back) {
front.next = back;
middle.next = back.next;
back.next = middle;
}
}