給定一個鏈表,兩兩交換其中相鄰的節點,並返回交換後的鏈表。
示例:
給定
1->2->3->4
你應該返回
2->1->4->3
說明:
你的算法只能使用常數的額外空間。
你不能只是單純的改變節點內部的值,而是需要實際的進行節點交換
class Solution {
public ListNode swapPairs(ListNode head) {
if (head == null || head.next == null) {
return head;
}
ListNode newTemp= new ListNode(0);
newTemp.next = head;
head = newTemp;
while (head.next != null && head.next.next != null) {
ListNode n1 = head.next;
ListNode n2 = head.next.next;
/* head->n1->n2->... => head->n2->n1->... */
head.next = n2;
n1.next = n2.next;
n2.next = n1;
head = n1;
}
return newTemp.next;
}
}