Swap nodes in a linked list in pairs
Title description:
Given a linked list, swap adjacent nodes in pairs and return the head of the swapped list. You must do this without changing the values inside the nodes (that is, swapping nodes only).
Idea 1: iterative method
- Set virtual node F
- Switch the last two virtual nodes f
- Virtual node F must be moved to the first node before the switch in Step 2
Set the role of the virtual node:
- The head node is unchanged, and the head node of the swapped linked list can be found quickly.
- The first node of the two nodes to be swapped, next, points correctly to the swapped node.
/** * Definition for singly-linked list. * function ListNode(val, next) { * this.val = (val===undefined ? 0 : val) * this.next = (next===undefined ? null : next) * } */ /** * @param {ListNode} head * @return {ListNode} */ var swapPairs = function(head) { if(head == null || head.next == null) return head; var node = new ListNode(-1); node.next = head; var f = node; while(f.next ! = null && f.next.next! =null) { var p = f.next,q=f.next.next; p.next = q.next; q.next = p; f.next = q; f = p; } return node.next; };Copy the code
Idea 2: Recursion
- The first node, next, points to the list after the second node, and the second node, next, points to the first node.
- For group 2 or more pairwise switches, perform the same operations as Step 1.
- Recursion terminates when the list is empty or when there is only one node.
/**
* Definition for singly-linked list.
* function ListNode(val, next) {
* this.val = (val===undefined ? 0 : val)
* this.next = (next===undefined ? null : next)
* }
*/
/**
* @param {ListNode} head
* @return {ListNode}
*/
var swapPairs = function(head) {
if(head == null || head.next == null) return head;
var p = head.next;
head.next = swapPairs(p.next);
p.next = head;
return p;
};
Copy the code
readme
Algorithm small white one, record their own algorithm learning road. If you find any problems, please leave a message.