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

相关推荐
东方芷兰17 分钟前
算法笔记 04 —— 算法初步(下)
c++·笔记·算法
JNU freshman19 分钟前
图论 之 迪斯科特拉算法求解最短路径
算法·图论
青松@FasterAI41 分钟前
【NLP算法面经】本科双非,头条+腾讯 NLP 详细面经(★附面题整理★)
人工智能·算法·自然语言处理
旅僧1 小时前
代码随想录-- 第一天图论 --- 岛屿的数量
算法·深度优先·图论
Emplace1 小时前
ABC381E题解
c++·算法
一个 00 后的码农1 小时前
25轻化工程研究生复试面试问题汇总 轻化工程专业知识问题很全! 轻化工程复试全流程攻略 轻化工程考研复试真题汇总
面试·面试问题·25考研·考研复试·考研调剂·面试真题·轻化工程
多敲代码防脱发1 小时前
Spring框架基本使用(Maven详解)
java·网络·后端·spring·maven
若兰幽竹1 小时前
【机器学习】衡量线性回归算法最好的指标:R Squared
算法·机器学习·线性回归
Asthenia04122 小时前
Mybatis实践——Wrapper&&三表联查&&BaseMapper和Service的功能分异
后端
刘小炮吖i2 小时前
Java基础常见的面试题(易错!!)
java·面试·职场和发展