C++:链表插入排序/删除重复节点题解

插入排序

插入排序的思路很简单,基本都知道。

关键是放在链表中,

1.要建立一个哨兵位,这个哨兵位的下一个节点,始终指向val最小的节点。

2.prev指针作为cur的前一个节点,始终指向val最大的节点。它的下一个节点始终指向cur/cur即将跳跃的待排序的节点。

3.cur指向待排序的第一个节点。

cur从第二个开始,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* insertionSortList(ListNode* head) {if(head==nullptr || head->next==nullptr){return head;}ListNode* dummy = new ListNode(0);//建立一个哨兵位,始终指向最小的dummy->next=head;ListNode* cur=head->next;ListNode* prev=head;while(cur){if(prev->val <= cur->val)//prev始终指向最大的,cur的前一个{prev=cur;cur=cur->next;}else{ListNode* tmp=dummy;while(tmp->next->val <= cur->val)//不用考虑走到空,这里一定有大于cur的值{tmp=tmp->next;}prev->next=cur->next;//标记,方便cur跳跃//cur插入tmp和tmp->next中cur->next=tmp->next;tmp->next=cur;//cur跳跃cur=prev->next;}}ListNode* newhead = dummy->next;delete dummy;return newhead;}
};

2.删除链表中的重复节点

分析:

1.删除重复节点可能会遇到连续多个重复节点,因此需要在循环进行。

2.删除的重复节点是头节点和不是头节点要分别处理,是头节点,那么头节点要换到next,不是头节点,就不需要更换头节点了。(最后返回头节点)

3.删除节点的方式,这题我使用的是跳过这个节点,而不是释放节点。

4.在判断cur节点和next节点值相等的循环中,跳出循环时,next走到下一个节点,下一个节点是空和不是空要分别处理。

这里要声明3个节点,头节点是已经给了的,始终指向第一个存在的位置,如果它要被删除,那么它要更换别的不被删除的位置,如果所有的节点都可以消消乐,那么就要让它指向空。

cur节点指向即将判断的第一个节点,next节点指向即将判断的第二个节点。如果判断不相等。prev就指向cur,cur和next依次往后走一个位置。prev永远指向安全的不被删除的位置,永远指向cur的前,当连续存在相等的值时,next一直往下走和cur判断。直到走到不等的位置时跳出,此时需要prev的next指针指向这个不与cur相等的更新的next,接着再更新cur和next的位置。

这道题可能会坑的地方基本指出,其余的就是逻辑上要考虑到所有情况,不能让任何一种情况遗漏了。

代码:

/*
struct ListNode {int val;struct ListNode *next;ListNode(int x) :val(x), next(NULL) {}
};
*/class Solution {
public:ListNode* deleteDuplication(ListNode* pHead) {if(pHead==nullptr || pHead->next==nullptr){return pHead;}ListNode* cur=pHead;ListNode* prev=nullptr;ListNode* next=pHead->next;while(next){if(cur->val==next->val){while(next&&cur->val==next->val){next=next->next;}if(cur==pHead&&next==nullptr){return nullptr;}else if(cur==pHead&&next!=nullptr){pHead=next;}else if(cur!=pHead &&next!=nullptr){prev->next=next;}else{prev->next=next;return pHead;}cur=next;if(next){next=cur->next;}}else{prev=cur;cur=next;next=next->next;}}return pHead;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3245819.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

C++ ─── vector的模拟实现

知识点&#xff1a; ① 因为vector是模版&#xff0c;所以声明和定义都放在.h中&#xff0c;防止出现编译错误。 .h不会被编译&#xff0c;在预处理中.h在.cpp中展开&#xff0c;所以在编译时只有.cpp 而 .cpp顺序编译&#xff0c;只会进行向上查找&#xff0c;因此至少有函数的…

交叉编译ethtool(ubuntu 2018)

参考文章&#xff1a;https://www.cnblogs.com/nazhen/p/16800427.html https://blog.csdn.net/weixin_43128044/article/details/137953913 1、下载相关安装包 //ethtool依赖libmul git clone http://git.netfilter.org/libmnl //ethtool源码 git clone http://git.kernel.or…

野兔在线工具箱系统全新升级改版,基于TP8和yetuadmin后台实现

野兔在线工具箱系统全新升级改版&#xff0c;基于TP8和yetuadmin后台实现 系统名称&#xff1a;野兔在线工具系统 系统语言&#xff1a;支持多语言&#xff0c;大概有20种 系统源码&#xff1a;不加密&#xff0c;开源 系统开发&#xff1a;PHPMySQL (基于thinkphp8&#x…

Docker容器——初识Docker,安装以及了解操作命令

一、Docker是什么? 是一个开源的应用容器引擎&#xff0c;基于go语言开发并遵循了apache2.0协议开源&#xff0c;用来管理容器和镜像的工具是在Linux容器里驱动运行应用的开源工具是一种轻量级的“虚拟机” 基于linux内核运行Docker的容器技术可以在一台主机上轻松为任何应用…

Pytorch的编译新特性TorchDynamo的工作原理和使用示例

在深度学习中&#xff0c;优化模型性能至关重要&#xff0c;特别是对于需要快速执行和实时推断的应用。而PyTorch在平衡动态图执行与高性能方面常常面临挑战。传统的PyTorch优化技术在处理动态计算图时效果有限&#xff0c;导致训练时间延长和模型性能不佳。TorchDynamo是一种为…

COHV 计划订单ALV界面添加字段

COHV 计划订单ALV界面添加字段 目录 增强点 包含文件&#xff1a;LCOWB01F02 这里是对ALV界面的显示字段输出值&#xff0c;输入结构为ls_header 结构添加字段 COWB_S_HEADER结构添加一个附加结构

Nginx入门到精通三(反向代理1)

下面内容整理自bilibili-尚硅谷-Nginx青铜到王者视频教程 Nginx相关文章 Nginx入门到精通一&#xff08;基本概念介绍&#xff09;-CSDN博客 Nginx入门到精通二&#xff08;安装配置&#xff09;-CSDN博客 Nginx入门到精通三&#xff08;Nginx实例1&#xff1a;反向代理&a…

Attention机制解析

Attention机制解析 1. 引言 Attention机制在自然语言处理&#xff08;NLP&#xff09;和计算机视觉&#xff08;CV&#xff09;等领域取得了广泛的应用。其核心思想是通过对输入数据的不同部分赋予不同的权重&#xff0c;使模型能够更加关注重要的信息。本文将详细介绍Attent…

独立开发者系列(27)——python生成文本

在简单的安全漏洞测试里面&#xff0c;文本的信息自动化填充生成和储存还有使用非常有用。简单的比如IP段的生成&#xff0c;检查某个IP段的服务器存在数量一般取俩个IP段 比如101.35.*.* 最多256*256 条IP 信息 分别发出对应的检测命令&#xff0c;可以知道该IP段有多少可以查…

F1-score(标准度量)

什么是F1-score&#xff1f; F1分数&#xff08;F1-score&#xff09;是分类问题的一个衡量指标。一些多分类问题的机器学习竞赛&#xff0c;常常将F1-score作为最终测评的方法。它是精确率和召回率的调和平均数&#xff0c;最大为1&#xff0c;最小为0&#xff0c;如公式1所示…

Java面试八股之简述单例redis并发承载能力

简述单例redis并发承载能力 单例Redis实例的并发承载上限受到多种因素的影响&#xff0c;包括但不限于硬件性能、网络条件、数据集大小、操作类型以及Redis自身的配置。以下是几个关键因素的详细说明&#xff1a; 硬件性能&#xff1a; CPU&#xff1a;Redis主要依赖于CPU的…

蓝桥 双周赛算法赛【小白场】

博客主页&#xff1a;誓则盟约系列专栏&#xff1a;IT竞赛 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ 蓝桥第14场小白入门赛T1/T2/T3 题目&#xff1a; T1照常还是送分题无需多…

【数据集处理工具】根据COCO数据集的json标注文件实现训练与图像的文件划分

根据COCO数据集的json标注文件实现训练与图像的文件划分 一、适用场景&#xff1a;二、COCO数据集简介&#xff1a;三、场景细化&#xff1a;四、代码优势&#xff1a;五、代码 一、适用场景&#xff1a; 适用于一个常见的计算机视觉项目应用场景&#xff0c;特别是当涉及到使…

硅谷裸机云多IP服务器怎么样?

硅谷裸机云多IP服务器是一种在硅谷地区提供的、具有多个IP地址的裸机云服务器。这种服务器结合了裸机服务器的高性能和云服务器的灵活性&#xff0c;同时提供了多个IP地址&#xff0c;为用户的各种需求提供了支持。以下是关于硅谷裸机云多IP服务器的一些详细信息&#xff0c;ra…

【Docker】Docker 的数据管理与镜像创建

目录 一.数据管理 1.数据卷 2.数据卷容器 二.端口映射 三.容器互联 四.Docker 镜像的创建 1.基于现有镜像创建 1.1.首先启动一个镜像&#xff0c;基于镜像创建容器&#xff0c;更新容器内容 1.2.将修改后的容器提交为新的镜像&#xff0c;需要使用该容器的 ID 号创建新…

嵌入式人工智能(9-基于树莓派4B的PWM-LED呼吸灯)

1、PWM简介 (1)、什么是PWM 脉冲宽度调制(PWM)&#xff0c;是英文“Pulse Width Modulation”的缩写&#xff0c;简称脉宽调制&#xff0c;是在具有惯性的系统中利用微处理器的数字输出来对模拟电路进行控制的一种非常有效的技术&#xff0c;广泛应用在从测量、通信到功率控制…

基于mcu固件反汇编逆向入门示例-stm32c8t6平台

基于mcu固件反汇编逆向入门示例-stm32c8t6平台 本文目标&#xff1a;基于mcu固件反汇编逆向入门示例-stm32c8t6平台 按照本文的描述&#xff0c;应该可以在对应的硬件上通实验并举一反三。 先决条件&#xff1a;拥有C语言基础&#xff0c;集成的开发环境&#xff0c;比如&am…

集线器、交换机、路由器的区别,冲突域、广播域

冲突域 定义&#xff1a;同一时间内只能有一台设备发送信息的范围。 分层&#xff1a;基于OSI模型的第一层物理层。 广播域 定义&#xff1a;如果某个站点发出一个广播信号&#xff0c;所有能接受到这个信号的设备的范围称为一个广播域。 分层&#xff1a;基于OSI模型的第二…

Makefile学习:第一章 GCC的简易用法

参考&#xff1a;《鸟哥的LINUX私房菜》 一、编译与链接 假设我们先在linux的控制台界面中使用 nano hello.c &#xff0c;进入文件后写一个简单的程序。现在要用GCC来编译运行&#xff0c;我们有两种方式&#xff1a; // hello.c #include <stdio.h>int main() {print…

PostgreSQL 中如何解决因大量并发删除和插入操作导致的索引抖动?

&#x1f345;关注博主&#x1f397;️ 带你畅游技术世界&#xff0c;不错过每一次成长机会&#xff01;&#x1f4da;领书&#xff1a;PostgreSQL 入门到精通.pdf 文章目录 PostgreSQL 中如何解决因大量并发删除和插入操作导致的索引抖动一、理解索引抖动二、索引抖动的影响三…