给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。
你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。
示例:
给定 1->2->3->4, 你应该返回 2->1->4->3.
思路:链表画张图最清晰。
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
class Solution {
public ListNode swapPairs(ListNode head) {
ListNode res = new ListNode(-1), dummy= res;
res.next = head;
while (dummy.next!=null && dummy.next.next!=null) {
ListNode temp = dummy.next.next;
dummy.next.next = temp .next;//图中第一步
temp .next = dummy.next;//图中第二步
dummy.next = temp ;//图中第三步
dummy= temp .next;
}
return res.next;
}
}