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;
    }
};
相关推荐
yszaygr213836 分钟前
Verilog参数化游程编码RLE模块
算法
望易1 小时前
刚设计的大模型架构-双域耦合认知框架
算法·架构
复杂网络5 小时前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
HjhIron20 小时前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩1 天前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
触底反弹1 天前
🧠 搞懂 Token,才算真正入门大模型——从分词原理到 Embedding 语义实战
javascript·人工智能·算法
vivo互联网技术1 天前
ICLR 2026 | 基于后验采样的图像恢复方法LearnIR:人脸去阴影、去雾
人工智能·算法·aigc
浮生望1 天前
JS字符串与回文算法:从包装类到双指针的面试进阶之路
javascript·算法
黄敬峰1 天前
面试必刷:从JS底层包装类到双指针,彻底搞懂字符串与回文算法
算法
地平线开发者2 天前
J6B vio scenario sample
算法