Leetcode 24 Swap Nodes in Pairs

server/2024/10/22 18:27:20/

题意:给定一个list of nodes,要求交换相邻的两个节点
https://leetcode.com/problems/swap-nodes-in-pairs/description/
Input: head = [1,2,3,4]
Output: [2,1,4,3]
首先你需要思考,我要交换两个节点,对于每个节点,向前指的指针会改变,🤔后指的指针也会改变,所以我需要三个指针来解决这个问题。
比较容易错的地方是prev指针指向的位置,永远应该是每一个需要改变节点的前一个指针

/*** 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) {return nullptr;}ListNode dummy = ListNode(-1);dummy.next = head;ListNode* prev = &dummy;while(prev->next && prev->next->next) {ListNode* p1 = prev->next;ListNode* p2 = prev->next->next;p1->next = p2->next;p2->next = p1;prev->next = p2;prev = p1;}return dummy.next;}
};

http://www.ppmy.cn/server/130111.html

相关文章

STM32 USB CUBEMX

开发背景 使用的平台:STM32H750 注意事项 时钟必须是48MHZ,其它都不行 2. 将默认任务的堆栈设大一点 如果使用操作系统,USB任务跑在默认任务里,因此需要设置默认任务的堆栈缓存是直接定义的全局变量,需要设置编译器…

【操作系统】——进程(手把手教你学进程,学不会你呼我)

🌹😊🌹博客主页:【Hello_shuoCSDN博客】 ✨操作系统详见 【操作系统专项】 ✨C语言知识详见:【C语言专项】 目录 一、进程的概念、组成、特征 1.1 进程的概念(理解“进程”和“程序”的区别)…

连肝了多天学习MySQL索引与性能优化,详细总结一下索引的使用与数据库优化

文章目录 索引是什么?索引的作用初步认识索引索引的类型按照数据结构分类BTREE索引 哈希索引 按功能逻辑进行分类唯一索引普通索引主键索引全文索引 按照字段的个数进行划分单列索引多列(组合,联合)索引 小结索引的设计原则数据准…

Python 如何使用 Redis 作为缓存

Python 如何使用 Redis 作为缓存 一、引言 在现代 Web 应用程序和数据密集型服务中,性能 和 响应速度 是至关重要的因素。而当应用需要频繁访问相同的数据时,直接从数据库获取数据会耗费大量的时间和资源。因此,缓存系统成为了提升性能的重…

【Verilog学习日常】—牛客网刷题—Verilog进阶挑战—VL45

异步FIFO 描述 请根据题目中给出的双口RAM代码和接口描述,实现异步FIFO,要求FIFO位宽和深度参数化可配置。 电路的接口如下图所示。 双口RAM端口说明: 端口名 I/O 描述 wclk input 写数据时钟 wenc input 写使能 waddr input 写…

解决Docker环境下Next.js和FastAPI的跨容器通信问题

在开发使用Docker容器化的全栈应用时,我们经常会遇到前后端通信的问题。本文记录了我们在使用Next.js作为前端,FastAPI作为后端的项目中遇到的一个棘手问题,以及最终的解决方案。 问题背景 我们的应用架构如下: 前端&#xff1…

vue3 elementUI 表单验证

1、前端配置正则表达式入存入数据库&#xff0c;前端表单反显校验 <script>const rgxFunc new RegExp(item.fieldRegexp.trim());const rules[];console.log(正则表达式, rgxFunc);console.log(正则表达式, rgxFunc.test(中文));rules.push({message: item.regexpTip ||…

飞行机器人专栏(十六)-- 双臂机器人体感交互式控制

目录 1. 概要 2. 整体架构流程 3. 控制系统设计 3.1 Vision-based Human-Robot Interaction Control 3.2 Human Motion Estimation Approach 4. 实现方法及实验验证 4.1 System Implementation 4.2 Experimental Setup 4.3 Experimental Results 5. 小结 ​​​​​​​ 1. 概…