1.题目

24. 两两交换链表中的节点

难度中等1112收藏分享切换为英文接收动态反馈
24. 两两交换链表中的节点 - 图1
给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。
你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。

示例 1:
输入:head = [1,2,3,4] 输出:[2,1,4,3]
示例 2:
输入:head = [] 输出:[]
示例 3:
输入:head = [1] 输出:[1]

提示:

  • 链表中节点的数目在范围 [0, 100] 内
  • 0 <= Node.val <= 100

    2.题解

解题思路

就注意一个的特殊情况,一个或者没有的话,不需要交换,
剩下交换保证两两交换,需要注意就先找到下一个,几个变量prev,cur,next,temp一一对应,因为要返回dum,所以用一个新的指针去遍历,修改指向。

代码

  1. /**
  2. * Definition for singly-linked list.
  3. * function ListNode(val, next) {
  4. * this.val = (val===undefined ? 0 : val)
  5. * this.next = (next===undefined ? null : next)
  6. * }
  7. */
  8. /**
  9. * @param {ListNode} head
  10. * @return {ListNode}
  11. */
  12. var swapPairs = function(head) {
  13. if (!head || !head.next) return head;
  14. let dum = new ListNode(-1);
  15. dum.next = head;
  16. let prev = dum;
  17. let cur = dum.next;
  18. while (cur && cur.next) {
  19. let next = cur.next;
  20. let temp = next.next;
  21. next.next = cur;
  22. cur.next = temp;
  23. prev.next = next;
  24. prev = cur;
  25. cur = temp;
  26. }
  27. return dum.next;
  28. };
  29. /**
  30. *
  31. *
  32. 输入:head = [1,2,3,4]
  33. 输出:[2,1,4,3]
  34. */