Leetcode24 —— 两两交换链表中的节点(迭代法)

目录

题目:

题解:

C++代码:

题目:

题解:

递归法不太好理解,这里讲解迭代法。

  • 哨兵节点兜底:创建虚拟头节点(dummyHead)指向原链表头,统一所有节点对的交换逻辑(避免头节点交换的特殊处理);

  • 循环遍历交换:用临时指针从哨兵节点开始,每次定位其后两个待交换节点(node1、node2),通过三步指针调整完成交换:

    复制代码
    temp→next = node2(把 node2 接到 temp 后);
    
    node1→next = node2→next(保留 node2 后续链表);
    
    node2→next = node1(完成两两交换);
  • 指针后移迭代:将临时指针移到交换后的第二个节点(node1),重复上述交换,直到剩余节点不足两个;

  • 清理返回:记录哨兵节点的 next(新链表头),释放哨兵节点内存,返回结果。

C++代码:

复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        ListNode* prehead = new ListNode(0);
        prehead->next = head;
        ListNode* temp  = prehead;
        while(temp->next && temp->next->next){
             ListNode* node1 = temp->next;
             ListNode* node2 = temp->next->next;
             //交换的三个步骤
             temp->next = node2;
             node1->next = node2->next;
             node2->next = node1;
             temp = node1; //更新temp的值容易忘;
        }
        ListNode* ans = prehead->next;
        delete prehead;
        return ans; // 返回交换后的链表头
    }
};
相关推荐
广州灵眸科技有限公司14 分钟前
瑞芯微(EASY EAI)RV1126B AI算法开发流程
人工智能·算法·机器学习
Rabitebla1 小时前
【C++】string 类:原理、踩坑与对象语义
linux·c语言·数据结构·c++·算法·github·学习方法
小雅痞2 小时前
[Java][Leetcode middle] 167. 两数之和 II - 输入有序数组
java·算法·leetcode
CN-Dust2 小时前
【C++】输入cin例题专题
java·c++·算法
数模竞赛Paid answer3 小时前
2025年MathorCup数学建模A题汽车风阻预测解题文档与程序
算法·数学建模·mathorcup
Old Uncle Tom9 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆9 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移9 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业9 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
智者知已应修善业12 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机