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、第一个节点前的节点,需要和交换后的后继节点关联上

相关推荐
dyyx11114 分钟前
C++中的过滤器模式
开发语言·c++·算法
2301_8187320626 分钟前
项目启动报错,错误指向xml 已解决
xml·java·数据库·后端·springboot
lrh12280036 分钟前
详解决策树算法:分类任务核心原理、形成流程与剪枝优化
算法·决策树·机器学习
期末考复习中,蓝桥杯都没时间学了40 分钟前
力扣刷题15
算法·leetcode·职场和发展
2301_817497331 小时前
C++中的装饰器模式高级应用
开发语言·c++·算法
m0_549416661 小时前
C++编译期字符串处理
开发语言·c++·算法
m0_581124191 小时前
C++中的适配器模式实战
开发语言·c++·算法
A尘埃1 小时前
零售连锁店生鲜品类销量预测——线性回归(Linear Regression)
算法·线性回归·零售
小王不爱笑1321 小时前
SpringBoot 整合 Ollama + 本地 DeepSeek 模型
java·spring boot·后端
無森~1 小时前
HBase优化面试题
java·面试·hbase