LeetCode(两两交换链表中的节点)

题目链接:

https://leetcode.cn/problems/swap-nodes-in-pairs/

题目描述:

给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

示例 1:

复制代码
输入:head = [1,2,3,4]
输出:[2,1,4,3]

示例 2:

复制代码
输入:head = []
输出:[]

示例 3:

复制代码
输入:head = [1]
输出:[1]

提示:

  • 链表中节点的数目在范围 [0, 100]
  • 0 <= Node.val <= 100

思路:

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){    
            //申请虚拟头结点
            ListNode* newhead=new ListNode(0);
            newhead->next=head;

            ListNode* cur=newhead;
            while(cur->next&&cur->next->next){//至少有两个有效结点才能交换
                ListNode* p=cur->next;//第一个节点
                ListNode* q=cur->next->next;//第二个节点

                //原始链表的第二结点变成新链表的头结点,
                cur->next=q;
                //先把后续节点连到原来头结点身上
                p->next=q->next;
                //原始链表的头结点变成新链表的第二个结点
                q->next=p;

                //让虚拟头结点移动到新链表第二节点的位置,开始新一轮
                cur=p;
            }
            return newhead->next;
        }
        return NULL;
    }
};
相关推荐
小宋加油啊1 小时前
机械臂抓取物体 PVN3D算法调研学习
学习·算法·3d
lqqjuly1 小时前
前沿算法深度解析(一)
算法
小欣加油1 小时前
leetcode1926 迷宫中离入口最近的出口
数据结构·c++·算法·leetcode·职场和发展
happymaker06264 小时前
LeetCodeHot100——42.接雨水
算法
阿正的梦工坊4 小时前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
努力努力再努力wz6 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
八解毒剂6 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
运行时记录6 小时前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
啦啦啦啦啦zzzz6 小时前
算法总结(二分查找、双指针)
c++·算法