力扣-链表-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;

    }
};
相关推荐
Lsk_Smion2 分钟前
Hot100(开刷) 之 长度最小的数组--删除倒数第N个链表--层序遍历
java·数据结构·算法·kotlin
luoganttcc3 分钟前
dim3 grid_size(2, 3, 4); dim3 block_size(4, 8, 4)算例
算法
WBluuue11 分钟前
Codeforces 1088 Div1+2(ABC1C2DEF)
c++·算法
蓝色的杯子19 分钟前
Python面试30分钟突击掌握-LeetCode3-Linked list
python·leetcode·面试
像素猎人21 分钟前
map<数据类型,数据类型> mp和unordered_map<数据类型,数据类型> ump的讲解,蓝桥杯OJ4567最大数目
c++·算法·蓝桥杯·stl·map
Narrastory21 分钟前
Note:强化学习(一)
人工智能·算法·强化学习
沐雪轻挽萤33 分钟前
1. C++17新特性-序章
java·c++·算法
郝学胜-神的一滴41 分钟前
从链表到二叉树:树形结构的入门与核心性质解析
数据结构·c++·python·算法·链表
csdn_aspnet1 小时前
C语言 (QuickSort using Random Pivoting)使用随机枢轴的快速排序
c语言·算法·排序算法
玖釉-1 小时前
深入解析 meshoptimizer:基于 meshopt_computeSphereBounds 的层级包围球构建与 DAG 优化
c++·算法·图形渲染