当前位置:   article > 正文

Leetcode 24:两两交换链表中的节点

Leetcode 24:两两交换链表中的节点

题目描述

给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

示例:

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

题目分析

首先需要知道,当头节点为空或者头节点的next为空时直接返回头节点

由于题目要求,最后返回为链表的头节点,但由于后续的操作过程中头节点会发生改变,所以可以引入一个节点(pre),使pre.next = head,这样后续操作完成后可以直接返回pre.next即可

调换temp.next与temp.next.next位置的具体方法见下列代码,自己画图比较直观

java解法

  1. /**
  2. * Definition for singly-linked list.
  3. * public class ListNode {
  4. * int val;
  5. * ListNode next;
  6. * ListNode() {}
  7. * ListNode(int val) { this.val = val; }
  8. * ListNode(int val, ListNode next) { this.val = val; this.next = next; }
  9. * }
  10. */
  11. class Solution {
  12. public ListNode swapPairs(ListNode head) {
  13. if(head == null || head.next == null){
  14. return head;
  15. }
  16. ListNode pre = new ListNode(0);
  17. pre.next = head;
  18. ListNode temp = pre;//引入节点
  19. while(temp.next != null && temp.next.next != null){
  20. //调换temp.next与temp.next.next位置,画图可以得出
  21. ListNode left = temp.next;
  22. ListNode right = left.next.next;
  23. temp.next = left.next;
  24. temp.next.next = left;
  25. left.next = right;
  26. temp = temp.next.next;
  27. }
  28. return pre.next;//返回结果
  29. }
  30. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/zyabc/article/detail/61214
推荐阅读
相关标签
  

闽ICP备14008679号