力扣-链表-24 两两交换链表中的节点

思路1

设置虚拟节点作为pre,第一个节点是cur,后一个是post,不断更换顺序并且更改好pre的next

代码1

cpp 复制代码
class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        if(!head) return head;
        ListNode* cur = head;
        ListNode* post =  head->next;
        ListNode* dummpy_head = new ListNode();
        dummpy_head->next = head;
        ListNode* pre = dummpy_head;
        while(post){
            ListNode* tmpCur = new ListNode();
            ListNode* tmpPost = new ListNode();
            if(post->next && post->next->next){
                tmpCur = post->next;
                tmpPost = tmpCur->next;
            }else{
                tmpCur = nullptr;
                tmpPost = nullptr;
            }
            pre->next = post;
            cur->next = post->next;
            post->next = cur;
            pre = cur;
            cur = tmpCur;
            post = tmpPost;
        }

        return dummpy_head->next;

    }
};
相关推荐
珂朵莉MM1 分钟前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--碳中和
人工智能·算法
良木生香3 分钟前
【数据结构-初阶】详解线性表(2)---单链表
c语言·数据结构·算法
牛三金4 分钟前
魔改-隐语PSI通信,支持外部通信自定义
服务器·前端·算法
菜鸟233号4 分钟前
力扣106 从中序与后序遍历序列构造二叉树 java实现
java·算法·leetcode
Donald_wsn8 分钟前
牛客 栈和排序 C++
数据结构·c++·算法
沃达德软件11 分钟前
智慧警务实战模型与算法
大数据·人工智能·算法·数据挖掘·数据分析
LYFlied19 分钟前
LeetCode热题Top100:核心算法思想与前端实战套路
前端·算法·leetcode·面试·算法思想·算法套路·解题公式
coderxiaohan20 分钟前
【C++】红黑树的实现
数据结构·c++·算法
AganTee23 分钟前
儿童编程学什么内容?怎么学?(附3个实用工具)
算法·青少年编程·推荐算法
coderxiaohan23 分钟前
【C++】封装红黑树实现mymap和myset
数据结构·c++·算法