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;
    }
};
相关推荐
aini_lovee2 分钟前
WSN 四大经典无需测距定位算法
算法
人道领域2 分钟前
【LeetCode刷题日记】掌握二叉树遍历:栈实现的三种绝妙方法
算法·leetcode·职场和发展
北冥湖畔的燕雀3 分钟前
深入解析Linux信号处理机制
算法
阿Y加油吧11 分钟前
二刷 LeetCode:动态规划经典双题复盘
算法·leetcode·动态规划
上弦月-编程26 分钟前
C语言指针超详细教程——从入门到精通(面向初学者)
java·数据结构·算法
莫等闲-29 分钟前
代码随想录一刷记录Day44——leetcode1143.最长公共子序列 53. 最大子序和
数据结构·c++·算法·leetcode·动态规划
生成论实验室29 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第七篇:社会与情感关系——连接、表达与共鸣
人工智能·算法·架构·交互·创业创新
承渊政道32 分钟前
【动态规划算法】(背包问题经典模型与解题套路)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
yyy(十一月限定版)1 小时前
数电1对应latex代码
算法
jieyucx1 小时前
Go语言切片:动态灵活的数据序列
算法·golang·指针·顺序表·数组·结构体·切片