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

相关推荐
Raink老师11 分钟前
用100道题拿下你的算法面试(矩阵篇-2):求转置矩阵
算法·面试·矩阵
算法鑫探6 小时前
闰年判断:C语言实战解析
c语言·数据结构·算法·新人首发
WBluuue6 小时前
数据结构与算法:康托展开、约瑟夫环、完美洗牌
c++·算法
我叫黑大帅7 小时前
通过eino-ext如何正常indexer RAG?
后端·面试·go
木子墨5167 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode
Ava的硅谷新视界7 小时前
用了一天 Claude Opus 4.7,聊几点真实感受
开发语言·后端·编程
王老师青少年编程8 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:均分纸牌
c++·算法·编程·贪心·csp·信奥赛·均分纸牌
EQUINOX18 小时前
2026年码蹄杯 本科院校赛道&青少年挑战赛道提高组初赛(省赛)第一场,个人题解
算法
萝卜小白8 小时前
算法实习Day04-MinerU2.5-pro
人工智能·算法·机器学习
Liangwei Lin8 小时前
洛谷 P3133 [USACO16JAN] Radio Contact G
数据结构·算法