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://www.mzph.cn/pingmian/47064.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JavaFX+MySQL实现图书管理系统(包含完整代码)

目录 一、功能介绍 1.ER图 2.学生管理员登陆页面 3.图书馆首页 4.学生图书馆搜索界面 5.学生注册 6.管理员后台 增加书籍 查看借阅记录 ​编辑 修改图书 二、功能分解 1.界面展示 2.点击按钮切换页面 普通按钮点击 复杂按钮点击 3.登录注册 创建登陆注册的页…

逆向学习思路链接分享

学好逆向先学C 然后我们需要学习好 编码问题CTF常见编码及加解密&#xff08;超全&#xff09; - ruoli-s - 博客园 (cnblogs.com) 并且规划好学习路线 CTF逆向Reverse入门学习路线&#xff08;面向小白&#xff09;_逆向reverse 思路-CSDN博客 并且安好反编译的环境 x64d…

linux学习笔记整理: 关于linux系统介绍 2024/7/16;

介绍: Linux&#xff0c;全称GNU/Linux&#xff0c;是一种免费使用和自由传播的类UNIX操作系统&#xff0c;其内核由林纳斯本纳第克特托瓦兹&#xff08;Linus Benedict Torvalds&#xff09;于1991年10月5日首次发布&#xff0c;它主要受到Minix和Unix思想的启发&#xff0c;是…

java使用字符缓冲流读写文件莫名消失

张三 李四 王二 麻子 狗蛋 小明 这是文件里的内容 package com.lu.day11;import java.io.*; import java.util.Map; import java.util.Random; import java.util.stream.Collectors;public class Test3 {public static void main(String[] args) {try (BufferedReader buffered…

Java 之BigDecimal 常用方法使用

BigDecimal.ZERO&#xff1a;表示值为零的 BigDecimal。 BigDecimal.ONE&#xff1a;表示值为一的 BigDecimal。 BigDecimal.TEN&#xff1a;表示值为十的 BigDecimal。 常用方法 1,add(BigDecimal augend)&#xff1a;加法运算 BigDecimal c BigDecimal.ZERO;//表示值为零的…

Android12 OTA全包升级清除用户数据

一般情况下进行OTA升级&#xff0c;是不会清除用户数据&#xff0c;如果想清除用户数据&#xff0c;制作升级包时添加–wipe_user_data参数。 制作清除用户数据的差分包 ./out/soong/host/linux-x86/bin/ota_from_target_files --wipe_user_data -v --block -p out/host/linu…

【教学类-67-02】20240716毛毛虫ABB排序

背景需求&#xff1a; 【教学类-67-01】20240715毛毛虫AB排序-CSDN博客文章浏览阅读584次&#xff0c;点赞16次&#xff0c;收藏6次。【教学类-67-01】20240715毛毛虫AB排序https://blog.csdn.net/reasonsummer/article/details/140443310 在AB排序基础上&#xff0c;继续制作…

微信小程序:模板语法

模板语法 微信小程序有自己单独的一套模板语法。 WXML 结构 WXML 数据写法和Vue相似&#xff0c;数据通过 {{}} 包裹。 <text>{{ msg }}</text>WXSS 样式 WXSS 具有 CSS 大部分的特性&#xff0c;小程序在 WXSS 也做了一些扩充和修改。 rpx 单位 rpx 将屏幕等分为 …

【Django+Vue3 线上教育平台项目实战】登录功能模块之短信登录与钉钉三方登录

文章目录 前言一、几个关键概念1.HTTP无状态性2.Session机制3.Token认证4.JWT 二、通过手机号验证码登录1.前端短信登录界面2.发送短信接口与短信登录接口3.Vue 设置interceptors拦截器4. 服务端验证采用自定义中间件方式实现5. 操作流程及效果图如下&#xff1a; 三、通过第三…

记录些MySQL题集(9)

MySQL之死锁问题分析、事务隔离与锁机制的底层原理剖析 一、MySQL中的死锁现象 所谓的并发事务&#xff0c;本质上就是MySQL内部多条工作线程并行执行的情况&#xff0c;也正由于MySQL是多线程应用&#xff0c;所以需要具备完善的锁机制来避免线程不安全问题的问题产生&#…

手机如何伪装ip网络地址

伪装IP地址是指通过技术手段修改网络设备的IP地址&#xff0c;使其看起来像是来自另一个网络位置。这种技术通常用于隐藏真实的网络活动&#xff0c;以保护隐私。那么&#xff0c;手机如何伪装IP网络地址&#xff1f; 要在手机上伪装IP地址&#xff0c;‌可以通过下载和安装手机…

Spring事件监听机制详解

Spring事件监听机制详解 在现代软件开发中&#xff0c;解耦和灵活性是两个非常重要的设计原则。Spring 框架通过事件驱动的编程模型&#xff0c;实现了组件之间的松耦合。本文将介绍Spring事件监听机制的原理&#xff0c;并通过示例展示如何实现这一机制。 什么是Spring事件监…

数据资产通证化,堪比20年前的房地产?

大数据产业创新服务媒体 ——聚焦数据 改变商业 想象一下&#xff0c;一个简单的点击&#xff0c;一次不经意的搜索&#xff0c;一段简短的对话&#xff0c;它们在数字世界里留下了什么&#xff1f;是的&#xff0c;是数据。这些看似微不足道的数字碎片&#xff0c;汇聚成海&a…

【python】PyQt5的窗口界面的各种交互逻辑实现,轻松掌控图形化界面程序

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

【中项】系统集成项目管理工程师-第一模块:IT技术和管理-1.1信息与信息化-1.1.2信息系统基础

前言&#xff1a;系统集成项目管理工程师专业&#xff0c;现分享一些教材知识点。 软考同样是国家人社部和工信部组织的国家级考试&#xff0c;全称为“全国计算机与软件专业技术资格&#xff08;水平&#xff09;考试”&#xff0c;目前涵盖了计算机软件、计算机网络、计算机应…

Dart语法问答到实践

语法问答 Dart语法输出调试信息的方法叫&#xff1f; print Dart语言里定义抽象类的关键字是&#xff1f; abstract Dart语言里String转Int的方法是&#xff1f; int.parse Dart语言的数据类型String是首字母大写&#xff0c;而int是首字母小写&#xff1f; 受c/c和java的影响&…

Office动态水印终于来了

在信息安全日益重要的今天&#xff0c;保护敏感信息变得尤为关键。目前&#xff0c;动态水印甚至是盲水印技术已经在各种企业软件中广泛应用&#xff0c;常见的钉钉和企业微信等都已经支持此类技术&#xff0c;用户查看消息时画面会显示对应用户的姓名和工号等&#xff0c;而作…

小程序-视图与逻辑

一、页面导航 声明式导航 编程式导航 导航传参 1.声明式导航传参 2.编程式导航传参 3.在onload中接收导航参数 二、页面事件 下拉刷新 上拉触底 三、生命周期 分类 生命周期函数分类 1.应用的生命周期函数 2.页面的生命周期函数 四、WXS脚本 基础语法 wxs的特点 五、案…

Matlab学习笔记01 - 基本数据类型

Matlab学习笔记01 - 基本数据类型 1、数据类型转换2、矩阵2.1 访问单个矩阵元素2.2 访问多个矩阵元素2.3 矩阵转置 3、字符与字符串4、数值与字符串5、元胞数组 1、数据类型转换 十进制转十六进制字符串‘FF’ >> hex2dec(3ff)ans 1023十进制转十六进制字符串 >>…

几何相关计算

目录 一、 判断两个矩形是否相交 二、判断两条线段是否相交 三、判断点是否在多边形内 四、垂足计算 五、贝塞尔曲线 六、坐标系 一、 判断两个矩形是否相交 当矩形1的最大值比矩形2的最小值都小&#xff0c;那矩形1和矩形2一定不相交&#xff0c;其他同理。 struct Po…