给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。
示例:
给定 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) {
if (head == null || head.next == null) return head;
ListNode duumy = new ListNode(0);
duumy.next = head;
ListNode l1 = duumy;
ListNode l2 = head;
while (l2 != null && l2.next != null) {
ListNode nextStart = l2.next.next;
l1.next = l2.next;
l2.next.next = l2;
l2.next = nextStart;
l1 = l2;
l2 = l2.next;
}
return duumy.next;
}
}
本文介绍了一种在常数额外空间下,两两交换链表中相邻节点的算法实现。通过实例展示,如将1->2->3->4转换为2->1->4->3。算法不仅改变了节点的值,还进行了实际的节点交换。
614

被折叠的 条评论
为什么被折叠?



