leetcode 24

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

已经给出了链表节点结构类:

public class ListNode {
     int val;
     ListNode next;
     ListNode() {}
     ListNode(int val) { this.val = val; }
     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 }

简而言之,我们对链表结构的改变(节点的增删改),本质上就是对其节点指针指向的改变,所以对于这道题目,我们不仅仅需要改变两两链表节点 firNode, secNode 之间的指针指向关系,还要考虑 firNode 前一个节点与secNode关系,以此来保证链表不会断裂。

由于需要考虑三个节点,我们可以选择定义一个哑节点 dummy, 前进指针指向 head 头节点,题目实现代码入下:

class Solution {
    public ListNode swapPairs(ListNode head) {
        ListNode dummy = new ListNode(0);
        dummy.next = head;
        ListNode curNode = dummy;
        while (curNode.next != null && curNode.next.next != null) {
            ListNode first = curNode.next;
            ListNode second = curNode.next.next;
            first.next = second.next;
            second.next = first;
            curNode.next = second;
            curNode = first;
        }
        return dummy.next;
    }
}

相关推荐

  1. leetcode 24

    2024-02-11 22:48:01       47 阅读
  2. LeetCode 24

    2024-02-11 22:48:01       57 阅读
  3. LeetCode hot100-24

    2024-02-11 22:48:01       35 阅读
  4. LeetCode 619, 58, 24

    2024-02-11 22:48:01       43 阅读
  5. LeetCode--26

    2024-02-11 22:48:01       53 阅读
  6. Leetcode--27

    2024-02-11 22:48:01       56 阅读
  7. LeetCode 21

    2024-02-11 22:48:01       43 阅读
  8. leetcode 23

    2024-02-11 22:48:01       38 阅读
  9. Leetcode274

    2024-02-11 22:48:01       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-11 22:48:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-11 22:48:01       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-11 22:48:01       82 阅读
  4. Python语言-面向对象

    2024-02-11 22:48:01       91 阅读

热门阅读

  1. 深度学习模型与神经网络可视化工具

    2024-02-11 22:48:01       50 阅读
  2. STM32 适合人群

    2024-02-11 22:48:01       50 阅读
  3. 12.3 OpenGL顶点后处理:平面着色

    2024-02-11 22:48:01       50 阅读
  4. C++ dfs的状态表示(五十二)【第十二篇】

    2024-02-11 22:48:01       53 阅读
  5. MSc CDA Take-Home

    2024-02-11 22:48:01       60 阅读
  6. golang 集成sentry:http.Client

    2024-02-11 22:48:01       50 阅读
  7. 20190726 ApacheHttpClient-自签证书与系统证书共存

    2024-02-11 22:48:01       49 阅读
  8. MySQL-管理

    2024-02-11 22:48:01       50 阅读
  9. 【力扣每日一题】力扣1696跳跃游戏VI

    2024-02-11 22:48:01       63 阅读
  10. Linux 服务管理两种方式service和systemctl

    2024-02-11 22:48:01       39 阅读