LeetCode第24题两两交换链表中的节点

继续打卡算法题,今天学习的是LeetCode的第24题两两交换链表中的节点,这道题目是道中等题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些帮助。

分析一波题目

这道题目很容易理解,容易读懂题意,我们只要掌握诀窍,通过前驱节点指向后续两个需要交换的节点,不断移动前驱节点,只要前驱节点的后面两个节点都存在,就执行交换,并移动前驱节点。

我们可以构造一个虚节点,指向头节点。第一次前驱节点等于虚拟节点

编码实现

java 复制代码
/**
 * Definition for singly-linked list.
 * 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; }
 * }
 */
class Solution {

    public ListNode swapPairs(ListNode head) {
        if(head == null || head.next == null) {
            return head;
        }
        //虚拟节点
        ListNode dumy = new ListNode();
        dumy.next = head;
        ListNode pre = dumy;
        while(pre.next != null && pre.next.next != null ) {
           
           //获取两个待交换位置的两个节点
           ListNode node1 =   pre.next;
           ListNode node2 =   pre.next.next;
           node1.next = node2.next;
           node2.next = node1;
           // 头节点替换 这里是关键,这里要想通,前驱节点每次都必须更新 pre前面的节点和新的后继节点关联上。
           pre.next = node2;
           pre = node1;
           
        }
        return dumy.next;
    }
}

总结

题意容易理解的题目,我们主要是注意细节,这道题目,交换链表节点需要考虑几个点:

1、两个节点交换,交换之后两个节点后续的节点已经天然关联上了。

2、第一个节点前的节点,需要和交换后的后继节点关联上

相关推荐
平凡但不平庸的码农34 分钟前
Go Slice 详解
算法·golang
kyriewen1 小时前
你还在手动敲命令部署?GitHub Actions 让你 push 即上线,摸鱼时间翻倍
前端·面试·github
怕浪猫1 小时前
荒岛原始无工业、无电力、无设备,从零搭建最基础计算机体系
人工智能·设计模式·面试
想学习java初学者2 小时前
SpringBoot整合Vertx-Mqtt多租户(优化版)
java·spring boot·后端
Csvn2 小时前
Python 性能优化与 Profiling 工具
后端·python
不减20斤不改头像3 小时前
手机一句话开发贪吃蛇!TRAE SOLO 移动端 AI 编程实测
前端·后端
明月_清风3 小时前
K8s 从入门到上手:核心概念+常用工具全解析
后端·kubernetes
随风,奔跑3 小时前
Nginx
服务器·后端·nginx·web
Jasmine_llq4 小时前
《B3867 [GESP202309 三级] 小杨的储蓄》
算法·循环遍历·数组累加(模拟)·索引定位·顺序输出
啦啦啦_99994 小时前
案例之 逻辑回归_电信用户流失预测
算法·机器学习·逻辑回归