力扣两两交换链表中的结点C++

题目


知识点

虚拟头节点


思路

注意交换的是整个结点,不是数值


错误

空指针异常

复制代码
while (cur->next && cur->next->next) { }

不能交换cur->next和cur->next->next,要是交换了,可能会找不到cur->next而发生空指针异常。


代码

cpp 复制代码
class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        ListNode* dummy = new ListNode(0, head);
        ListNode* cur = dummy;
        //不能交换顺序,不然cur->next->next走到cur->next的时候就可能空,发生空指针异常
        while (cur->next && cur->next->next) {
            ListNode* temp = cur->next;
            ListNode* temp1 = cur->next->next->next;
            cur->next = cur->next->next;
            cur->next->next = temp;
            temp->next = temp1;
            cur = cur->next->next;
        }
        return dummy->next;
    }
};
相关推荐
BadBadBad__AK22 分钟前
线段树维护区间 k 次方和
c++·数学·算法·stl
卷无止境12 小时前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
_清歌13 小时前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法
统计实现局13 小时前
SVD 的三步走:双对角化、Givens 收敛、排序
算法
躬行见万象13 小时前
《VLA 系列》UniLab 强化训练 | G1 机器人 |复现
算法
统计实现局13 小时前
对称不定分解(Bunch-Kaufman):为什么 Cholesky 不够用
算法
统计实现局13 小时前
dqrsl 拆解:拿着 QR 结果能算出哪 5 种东西
算法
卷无止境13 小时前
OpenMPI、MPICH 与 OpenMP:关系、核心概念与架构全解
c++·后端
统计实现局13 小时前
为什么 Cholesky 求逆比 Gauss-Jordan 快一倍——行列式溢出防护详
算法