Given a linked list, swap every two adjacent nodes and return its head.
You may not modify the values in the list's nodes, only nodes itself may be changed.
Example:
Given 1->2->3->4, you should return the list as 2->1->4->3.
代码
Approach #1 Recursive Approach
/** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode(int x) { val = x; } * } */classSolution {publicListNodeswapPairs(ListNode head) {if (head ==null||head.next==null) {return head; }ListNode firstNode = head;ListNode secondNode =head.next;firstNode.next=swapPairs(secondNode.next);secondNode.next= firstNode;return secondNode; }}