当前位置: 首页 > news >正文

【C++】链表操作技巧综合:重排链表(带你理顺链表的做题思路)

1.题目

2.算法思路

这是一道关于链表的综合题,一共涉及到三个步骤,其中每个步骤单拎出来就可以当一道单独的题目。所以需要大家对链表的操作十分熟悉,否则可能需要大量的时间做这道题目,而且还要很多的bug。

第一个步骤:

找到链表的中间结点。

技巧:快慢双指针。快指针往后走两步,慢指针往后走一步,当快指针走到链表的结尾时,慢指针刚好落在链表的中间位置。

注意:当链表有偶数个结点时,想要改变慢指针最后的落点,可以在链表前面插入一个哨兵位的头结点。

第二个步骤:

翻转后半部分的链表。

这里依然需要一个哨兵位的头结点,这样可以大大降低代码的复杂程度,也可以排除边界情况。总之,做链表的题目离不开哨兵位的头结点,能用就用。

然后往这个哨兵位的头结点后边一直头插就可以实现链表的翻转。

第三个步骤:

两个链表的合并。

这里需要双指针和哨兵位的头结点,分别遍历两个链表,然后分别在哨兵位的头结点后尾插即可完成题目!

3.思路总结

不只是针对这一道题目,而是针对所有的链表题目:

1.尽量多运用哨兵位的头结点。

2.尽量避免在原链表上做修改,这样代码会显得很乱。尽可能在哨兵位的头结点后进行尾插或头插,这样更有条理。

4.代码

void reorderList(ListNode* head) {if(head==nullptr||head->next==nullptr||head->next->next==nullptr) return;//快慢双指针,寻找中间结点ListNode* newhead=new ListNode(0,head);ListNode* slow=newhead,*fast=newhead;while(fast&&fast->next){slow=slow->next;fast=fast->next->next;}//从中间位置断开链表ListNode* cur=slow->next;slow->next=nullptr;//利用头插法翻转后半部分的链表ListNode* ret=new ListNode(0);ListNode* prev=ret;while(cur){ListNode* next=cur->next;cur->next=prev->next;prev->next=cur;cur=next;}//合并两个链表(双指针)ListNode* head1=new ListNode(0);ListNode* cur1=head,*cur2=ret->next,*prev1=head1;while(cur1){if(cur1){prev1->next=cur1;prev1=cur1;cur1=cur1->next;}if(cur2){prev1->next=cur2;prev1=cur2;cur2=cur2->next;}}//释放哨兵位的头结点,防止内存泄漏。delete newhead;delete ret;delete head1;}

相关文章:

【C++】链表操作技巧综合:重排链表(带你理顺链表的做题思路)

1.题目 2.算法思路 这是一道关于链表的综合题,一共涉及到三个步骤,其中每个步骤单拎出来就可以当一道单独的题目。所以需要大家对链表的操作十分熟悉,否则可能需要大量的时间做这道题目,而且还要很多的bug。 第一个步骤&#xf…...

行为型设计模式2:观察者/职责链/中介者/访问者

设计模式:观察者/职责链/中介者/访问者 (qq.com)...

叛逆,批判

1、对以往说法的批判之一(第一次这么公开批判是2004-2005年): 这部英文版的《数学百科全书》似乎是从俄语版翻译过来的?我查了三本引用的图书文献,都没有关于“nonsingular”和“singular”的类似下面的说法&#xff…...

Linux 命令,mkdir说明与使用

1:mkdir命令功用: 用于创建一个或多个目录,创建目录,必须在父目录中写上权限。 新目录的默认模式为0777,可以由系统或用的umask来修改。 2:命令构件: mkdir [options] directories 3:参数选项: -m&#x…...

24. 两两交换链表中的节点(Java)

目录 题目描述:示例 :代码实现: 题目描述: 给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换&am…...

linux虚拟机设置固定ip

修改/etc/sysconfig/network-scripts目录下ifcfg-eth0文件,各虚拟机这个文件名不一致,ifcfg-XX格式 vim /etc/sysconfig/network-scripts/ifcfg-eth0BOOTPROTO设置为static,然后在最后添加固定IP地址和默认网关、DNS等配置,IP地址…...

mysql问题解决

1.etl数据同步时,发现连接不上要同步的数据库 解决方法:关闭mysql的ssl,步骤如下: 在MySQL中禁用SSL连接涉及修改服务器的配置文件(通常是my.cnf或my.ini,取决于你的操作系统和MySQL版本)。以…...

类和对象(下)C++

1.初始化列表 1.为什么有初始化列表,它的作用? ->初始化列表,是构造函数初始化的另一种形式。 ->在语法上面理解,初始化列表可以认定为是每个成员变量定义初始化的地方. ->引用成员变量,const成员变量&am…...

常用在线 Webshell 查杀工具推荐

一、简介 这篇文章将介绍几款常用的在线 Webshell 查杀工具,包括长亭牧云、微步在线云沙箱、河马和VirusTotal。每个工具都有其独特的特点和优势,用于帮助用户有效检测和清除各类恶意 Webshell,保障网站和服务器的安全。文章将深入探讨它们的…...

RPC远程调用框架Dubbo

一、分布式服务调用_什么是RPC RPC(Remote Procedure Call)远程过程调用,它是一种通过网络从远程计算机程序上请求服务。 大白话理解就是:RPC让你用别人家的东西就像自己家的一样。 RPC两个作用: 屏蔽远程调用跟本地调用的区别&#xff0c…...

基于STM32的智能灌溉系统

目录 引言环境准备工作 硬件准备软件安装与配置系统设计 系统架构硬件连接代码实现 初始化代码传感器读取和控制代码应用场景 农业灌溉花园自动灌溉常见问题及解决方案 常见问题解决方案结论 1. 引言 智能灌溉系统通过实时监测土壤湿度和环境温度,自动控制灌溉设…...

Datawhale AI 夏令营 Task3(半成品,仍在学习理解

课程链接 / 知识点整理 (一)...

细腻呵护静音生活缓冲器,家具中的隐形侍者

在忙碌的生活节奏中,家是我们寻找宁静与放松的避风港。而家具缓冲器,就像一位隐形的侍者,在不经意间为我们营造出温馨、宁静的居住环境。它们静静地工作,细腻地呵护着每一处细节,让家的每一次触碰成为一次尊享体验。 细…...

【MATLAB源码-第243期】基于simulink的CUK斩波电路仿真,输出各节点波形。

操作环境: MATLAB 2022a 1、算法描述 CUK电路是一种高效的直流-直流转换器,它以其独特的能量传递方式和高效的电压转换能力,在许多电力电子应用中得到了广泛的使用。下面将详细描述CUK电路的工作原理、各个组成部分以及其在实际应用中的优…...

springboot项目不能同时跑junit4和junit5的解决方法

springboot项目的maven test只会跑junit4 RunWith注解的测试类&#xff0c;而不会跑junit5 ExtendWith的测试类 解决方法&#xff1a;pom加上以下plugin&#xff0c;版本号需要3.0.0-M5及以上 <plugin><groupId>org.apache.maven.plugins</groupId><art…...

【IO】使用消息队列完成两个进程之间相互通信

目录 1、使用消息队列完成两个进程之间相互通信 2、共享内存实现两个进程之间的通信 3、思维导图 1、使用消息队列完成两个进程之间相互通信 //msgsnd.c #include <myhead.h>// 要发送的消息类型 struct msgbuf {long mtype;char mtext[1024]; };// 定义一个宏&#…...

Web开发:用C#的逻辑理解VUE语法(VUE + Webapi小白开发笔记)

适用阅读对象&#xff1a;需要兼顾前端的C#后端开发人员&#xff08;基础笔记&#xff09; 目录 一、后端交互-获取实体数据 二、变量 1.声明 2.作用域 三、字符串的处理 四、数组(列表)的处理 1.数组中的SELECT语法&#xff08;提取特定字段到新数组&#xff09; 2.数…...

操作系统文件位置指针

文件位置指针 与标准IO的文件读写位置指针一样&#xff0c;系统IO时也会有一个表示位置的指针在移动&#xff0c;会随着读写操作的执行向后自动移动 当需要随机位置进行读写操作时&#xff0c;那么需要移动位置指针的位置 off_t lseek(int fd, off_t offset, int whence); 功…...

设计模式的概念

设计模式主要分为三类&#xff1a;创建类的设计模式、结构型设计模式、行为型设计模式。 创建类的设计模式&#xff1a;简单工厂&#xff0c;工厂模式&#xff0c;抽象工厂&#xff0c;建造者&#xff0c;单例&#xff0c;原型 结构型设计模式&#xff1a;代理模式、享元模式 行…...

VMware17下载与安装

1.下载 通过百度网盘分享的文件&#xff1a;VMware17 链接&#xff1a;https://pan.baidu.com/s/1gCine3d3Rp_l3NYAu5-ojg 提取码&#xff1a;ek25 --来自百度网盘超级会员V3的分享 2.安装...

春联生成模型在软件测试中的应用:自动化生成测试文本数据

春联生成模型在软件测试中的应用&#xff1a;自动化生成测试文本数据 最近和几个做软件测试的朋友聊天&#xff0c;他们都在为一个问题头疼&#xff1a;测试中文相关的软件时&#xff0c;怎么才能搞到足够多、足够“怪”的文本数据&#xff1f;比如测试输入法会不会因为某些生…...

生态环评实战指南:遥感解译、生物多样性建模与景观格局分析技术全流程

1. 生态环评技术框架解析 生态环评就像给地球做体检&#xff0c;需要一套系统化的检查流程。我参与过多个复合型项目评估&#xff0c;发现最关键的环节往往在前期框架搭建。最新技术导则要求采用"陆域-水域"一体化评估模式&#xff0c;这意味着我们需要同时关注森林、…...

AI原生研发不是“加AI”,而是重构研发DNA(SITS2026白皮书核心框架首次解密)

第一章&#xff1a;什么是AI原生软件研发&#xff1f;SITS2026给你答案 2026奇点智能技术大会(https://ml-summit.org) AI原生软件研发不是对传统开发流程的简单增强&#xff0c;而是以大模型为第一公民、以提示工程与推理编排为基本范式、以LLM-as-OS架构为底层支撑的全新研发…...

深入解析 Chromium 中的 Mojo IPC 消息机制及其实现

1. Mojo IPC 消息机制概述 Chromium 浏览器采用多进程架构设计&#xff0c;渲染进程&#xff08;Renderer Process&#xff09;和浏览器主进程&#xff08;Browser Process&#xff09;之间需要高效可靠的通信机制。Mojo 作为 Chromium 的进程间通信&#xff08;IPC&#xff09…...

Moe-Counter:让网站计数变得萌萌哒的终极解决方案

Moe-Counter&#xff1a;让网站计数变得萌萌哒的终极解决方案 【免费下载链接】Moe-Counter Moe counter badge with multiple themes! - 多种风格可选的萌萌计数器 项目地址: https://gitcode.com/gh_mirrors/mo/Moe-Counter Moe-Counter 是一款功能强大且风格多样的萌…...

【AI原生代码审查实战指南】:2026奇点大会首发的7大审查范式与3类高危漏洞自动拦截模型

第一章&#xff1a;2026奇点智能技术大会&#xff1a;AI原生代码审查 2026奇点智能技术大会(https://ml-summit.org) 在2026奇点智能技术大会上&#xff0c;“AI原生代码审查”不再作为辅助工具存在&#xff0c;而是深度嵌入软件开发生命周期的每个环节——从提交前的本地预检…...

动态规划之【树形DP】第2课:树形DP应用案例实践1

动态规划之【树形DP】第2课&#xff1a;树形DP应用案例实践1 二叉苹果树 题目描述 有一棵苹果树&#xff0c;如果树枝有分叉&#xff0c;一定是分二叉&#xff08;就是说没有只有一个儿子的结点&#xff09; 这棵树共有 NNN 个结点&#xff08;叶子点或者树枝分叉点&#xf…...

[Refactor]CPP Learn Data Day 信

一、什么是urllib3&#xff1f; urllib3 是一个用于处理 HTTP 请求和连接池的强大、用户友好的 Python 库。 它可以帮助你&#xff1a; 发送各种 HTTP 请求&#xff08;GET, POST, PUT, DELETE等&#xff09;。 管理连接池&#xff0c;提高网络请求效率。 处理重试和重定向。 支…...

线性规划实战指南:从基础理论到优化应用

1. 线性规划基础&#xff1a;从菜市场砍价到数学建模 第一次听说线性规划时&#xff0c;我正蹲在菜市场跟大妈讨价还价。大妈说&#xff1a;"西红柿3块一斤&#xff0c;买5斤送半斤"&#xff0c;我脑子里瞬间闪过一道光——这不就是典型的线性约束条件吗&#xff1f;…...

Redis:延迟双删的适用边界与落地细节寺

pagehelper整合 引入依赖com.github.pagehelperpagehelper-spring-boot-starter2.1.0compile编写代码 GetMapping("/list/{pageNo}") public PageInfo findAll(PathVariable int pageNo) {// 设置当前页码和每页显示的条数PageHelper.startPage(pageNo, 10);// 查询数…...