【剑斩OFFER】算法的暴力美学——两两交换链表中的结点

一、题目描述

二、算法原理

思路:引入哨兵位 + 3 个指针

为什么要引入哨兵位?当我们实现完第一次交换时:

prev 的 next 要指向 cur ,所以引入哨兵位,这样一次循环就能搞定交换两两结点;这里我为什么要引入 nnext ?其实是为了方便对两个结点时的交换。

循环结束的条件:

当结点为偶数时:next == nullptr 就结束循环

当结点为奇数时:cur == nullptr 就结束循环

三、代码实现

cpp 复制代码
/**
 * 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) {
        if(head == nullptr || head->next == nullptr) return head;
        ListNode* prev = new ListNode(0,head);
        ListNode* cur = head,*next = head->next,*nnext = next->next,*ret = next;
        while(cur && next)
        {
            next->next = cur;
            cur->next = nnext;
            prev->next = next;//对交换后的结点进行连接
            prev = cur;//开始更新 cur 、prev 、 next 、nnext
            cur = nnext;
            if(cur) next = cur->next;
            else break;
            if(next) nnext = next->next;
        }
        return ret;
    }
};

探索性代码:

cpp 复制代码
/**
 * 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* ret = nullptr;
        if(head == nullptr || head->next == nullptr) return head;
        else ret = head->next;//保存第一次交换的头结点
        ListNode* prev = head;
        ListNode* cur = head->next;
        ListNode* tmpnode = nullptr;
        ListNode* swapnode = nullptr;//保存交换后的prev
        while(cur != nullptr)//使用临时变量来进行两两交换
        {
            tmpnode = cur->next;
            cur->next = prev;
            prev->next = tmpnode;
            if(swapnode) swapnode->next = cur;//第二次,两两交换时,要把 prev 前一个结点链接上交换后的 cur
            swapnode = prev;
            prev = tmpnode;
            if(prev)
                cur = prev->next;
            else break;
        }
        return ret;
    }
};
相关推荐
AI科技星3 小时前
科幻艺术书本封面:《全域数学》第一部·数术本源 第三卷 代数原本(P95-141)完整五级目录【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
风筝在晴天搁浅3 小时前
LeetCode 92.反转链表Ⅱ
算法·leetcode·链表
王老师青少年编程4 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【贪心与二分判定】:数列分段 Section II
c++·算法·贪心·csp·信奥赛·二分判定·数列分段 section ii
V搜xhliang02464 小时前
OpenClaw科研全场景用法:从文献到实验室的完整自动化方案
运维·开发语言·人工智能·python·算法·microsoft·自动化
汉克老师4 小时前
GESP2025年3月认证C++五级( 第三部分编程题(2、原根判断))
c++·算法·模运算·gesp5级·gesp五级·原根·分解质因数
数据皮皮侠5 小时前
上市公司创新韧性数据(2000-2024)|顶刊同款 EIR 指数
大数据·人工智能·算法·智慧城市·制造
WL_Aurora5 小时前
Python 算法基础篇之链表
python·算法·链表
科研前沿5 小时前
纯视觉无感解算 + 动态数字孪生:室内外无感定位技术全新升级
大数据·人工智能·算法·重构·空间计算
代码中介商5 小时前
数据结构开篇:从问题到解决方案
数据结构
Wadli5 小时前
26.单调栈
算法