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;
    }
};
相关推荐
wsoz2 小时前
Leetcode矩阵-day7
c++·算法·leetcode·矩阵
念越2 小时前
算法每日一题 Day01|双指针解决移动零问题
java·算法·力扣
不想看见4042 小时前
Merge k Sorted Lists 优先队列--力扣101算法题解笔记
笔记·算法·leetcode
_深海凉_2 小时前
LeetCode热题100-合并区间
算法·leetcode·职场和发展
6Hzlia2 小时前
【Hot 100 刷题计划】 LeetCode 79. 单词搜索 | C++ 标准方向数组 DFS 与回溯
c++·leetcode·深度优先
wuweijianlove2 小时前
算法性能测试中的输入规模与边界影响的技术6
算法
MicroTech20252 小时前
微算法科技(NASDAQ :MLGO)量子增强区块链联邦学习:基于量子拜占庭协议的技术革新
科技·算法·区块链
山河君2 小时前
从后验到先验:语音信噪比估计与DD算法详解
算法·音视频·语音识别·信号处理
阿Y加油吧2 小时前
栈的经典应用:字符串解码 & 每日温度 深度解析
数据结构·python·算法