牛客热题:单链表排序

📟作者主页:慢热的陕西人

🌴专栏链接:力扣刷题日记

📣欢迎各位大佬👍点赞🔥关注🚓收藏,🍉留言

在这里插入图片描述

文章目录

  • 牛客热题:单链表排序
    • 题目链接
    • 方法一:用数组排序再赋值回来
      • 思路
      • 代码
      • 复杂度
    • 方法二:归并排序
      • 思路
      • 代码
      • 复杂度

牛客热题:单链表排序

题目链接

单链表的排序_牛客题霸_牛客网 (nowcoder.com)

方法一:用数组排序再赋值回来

思路

  • 用数组先将链表中的值存储起来
  • 对数组进行排序
  • 将数组的值赋值给链表

代码

    ListNode* sortInList(ListNode* head) {vector<int> v;ListNode* cur = head;while(cur != nullptr){v.push_back(cur->val);cur = cur->next;}sort(v.begin(), v.end());cur = head;for(auto & vv : v){cur->val = vv;cur = cur->next;}return head;}

复杂度

时间复杂度:O( N l o g N NlogN NlogN),用了c++原生的sort,底层是快排。

空间复杂度;O(N),借用了额外的数组空间

方法二:归并排序

思路

  • 先将原先的链表,对半分开直到不能再分(单个节点的情况)
  • 然后再将他们按照有序的方式合并

分开:

  • 快慢指针的思路,快指针一步走两个节点,慢指针一步走一个节点
  • 当快指针到达链表结尾的时候,那么这时候,慢指针恰好就在链表的中间位置
  • 我们从这块将两个链表分开就好

合并:

  • 创建一个哨兵位
  • 遍历比较排序好的左右单链表区间
  • 并逐个比较,尾插到哨兵位

代码

    ListNode* sortInList(ListNode* head) {if(head == nullptr || head->next == nullptr) return head;//快慢指针寻找链表的中点ListNode* fast = head->next;ListNode* slow = head;while(fast != nullptr && fast->next != nullptr){slow = slow->next;fast = fast->next->next;}//将链表从中间分开ListNode* temp = slow->next;slow->next = nullptr;//递归左右两边进行排序ListNode* left = sortInList(head);ListNode* right = sortInList(temp);//创建新的链表,带有哨兵位ListNode* h = new ListNode(0);ListNode* res = h;        //合并left和right两个链表while(left != nullptr && right != nullptr){if(left->val < right->val){h->next = left;left = left->next;}else {h->next = right;right = right->next;}h = h->next;}//最后查看left和right哪个还有剩余未添加的节点h->next = left == nullptr ? right : left;return res->next; }

复杂度

时间复杂度:O( N l o g N Nlog N NlogN),利用归并排序的思路实现。

空间复杂度:O(1),借用了常数个额外的空间。

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

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

相关文章

如何压缩word文档的大小?6个方法教你方便的压缩word文档

如何压缩word文档的大小&#xff1f;6个方法教你方便的压缩word文档 以下是六个常用的软件和方法&#xff0c;可以帮助您方便地压缩Word文档大小&#xff1a; 使用Microsoft Word内置功能&#xff1a; 在Microsoft Word中&#xff0c;您可以使用内置的压缩功能来减小文档的大…

单通道合并为三通道输入resnet网络

我们在做多序列任务时&#xff0c;一个患者会有多个序列的图像&#xff0c;每个序列的图像都是1通道的灰度图像&#xff0c;我们可以把一个患者的多有序列合并为多通道输入网络&#xff0c;这里举个3序列的例子。 1.输入之前合并 在输入之前将三张1通道合并为3通道图像&#…

Celery(分布式任务队列)入门学习笔记

Celery 的简单介绍 用 Celery 官方的介绍&#xff1a;它是一个分布式任务队列; 简单&#xff0c;灵活&#xff0c;可靠的处理大量消息的分布式系统; 它专注于实时处理&#xff0c;并支持任务调度。 Celery 如果使用 RabbitMQ 作为消息系统的话&#xff0c;整个应用体系就是下…

25.哀家要长脑子了---哈希表

1.525. 连续数组 - 力扣&#xff08;LeetCode&#xff09; 在我对通义千问的一番折磨下&#xff0c;终于弄清楚一点点了。哈希表存储前缀和数组值 用一个counter来记录nums中0、1数量差值的变化。 哈希表map存储某个特定的counter值首次出现的位置。counter的计算&#xff1a;…

【深度学习】序列模型

深度学习&#xff08;Deep Learning&#xff09;是机器学习的一个分支领域&#xff1a;它是从数据中学习表示的一种新方法&#xff0c;强调从连续的层中进行学习&#xff0c;这些层对应于越来越有意义的表示。 1. 为什么选择序列模型&#xff1f; 循环神经网络&#xff08;RNN…

python之 函数相关知识解析

01 函数的注释与嵌套 1.函数的注释 函数的注释与普通注释的区别&#xff1a;用来说明当前函数的参数含义 param 参数名: 参数的注释信息 return: 函数的返回值 例如&#xff1a; def fun1(name):""":param name: 参数的注释信息:return: 函数的返回值"…

(二)JSP教程——taglib指令

创建标签文件 首先创建一个Web项目&#xff0c;在webapp/WEB-INF目录下创建一个tags文件夹 在tags文件夹中创建一个oddNumberSum.tag文件&#xff0c;Tag文件时扩展名为.tag的文本文件&#xff0c;其结构和JSP文件非常相似&#xff0c;该文件的目录结构如图所示 创建Tag文件的…

Linux基础之makefile/make

目录 一、背景 二、makefile和make的讲解 2.1 使用方法 2.2 伪目标文件 2.3 文件的属性以及属性的更新 2.4 makefile的自动推导 一、背景 这里会提及为什么要使用makefile和make&#xff0c;以及他们是什么和作用。 会不会写makefile&#xff0c;从一个侧面说明了一个人是…

cache数据库在信创中的应用

Cache数据库在信创&#xff08;信息技术应用创新&#xff09;中的应用主要体现在其高性能、高可用性、灵活性和易用性等方面&#xff0c;这些特点使得Cache数据库在信创领域具有广泛的应用前景。 首先&#xff0c;Cache数据库作为后关系型数据库&#xff0c;能够整合对象数据库…

怎么口语外教一对一课程?这篇文章告诉你答案!

怎么口语外教一对一课程&#xff1f;在当今全球化的时代&#xff0c;英语口语能力已经成为许多人追求的重要技能。为了满足这一需求&#xff0c;市场上涌现出了许多提供一对一口语外教课程的软件。这些软件不仅提供了与母语为英语的外教进行实时交流的机会&#xff0c;还通过互…

Java之String类

一、String类常用方法 1.引用类型的比较 我们知道在Java中两个引用遍历是不能用" "号来比较的&#xff0c;而String类重写了父类objects的equals方法&#xff0c; 实现了引用类型的比较 例子 import java.util.Scanner; public class Main { public static void…

遭遇.halo勒索病毒怎么办?如何识别和应对.halo勒索病毒

导言&#xff1a; 近年来&#xff0c;网络安全问题愈发严峻&#xff0c;其中勒索病毒成为了威胁企业和个人数据安全的重要隐患。在2023年初&#xff0c;一种新的勒索病毒——.halo勒索病毒开始在网络上肆虐&#xff0c;给广大用户带来了极大的困扰。本文91数据恢复将对.halo勒…

c3 笔记6 认识css样式表

<link>与import应该如何选择?事实上&#xff0c;使用link与import链接外部样式文件的效果看起来是一样的&#xff0c;区别在于<link>是HTML标记而import属于CSS语法。<link>标记有rel、type与href属性&#xff0c;可以指定CSS样式表的名称&#xff0c;这样就…

C#中override与重载的区别

在C#中&#xff0c;override和重载&#xff08;通常通过定义具有相同名称但不同参数列表的方法来实现&#xff09;是两个不同的概念&#xff0c;它们在用途和行为上有所区别。下面是关于override和重载的主要区别&#xff1a; override&#xff08;重写&#xff09; 定义&…

控制台调试 hover 后才出现的元素

调试 hover后才出现的元素 打开开发者工具&#xff0c;鼠标放在hover时才出现的元素上&#xff0c;然后点击右键&#xff1b; 不要选中任何选项&#xff0c;将鼠标移动到开发者工具的调试面板中&#xff1b; 按下N键&#xff0c;此时悬浮的元素不会消失&#xff0c;定位成功。…

知到java笔记(4.1--继承的用法以及this和super的用法)

格式&#xff1a; 例子&#xff1a; get set获取父类的私有变量 private属性 this和super区别&#xff1a; this用法 super用法 例子

计算机毕设

随着社会和国家的重视&#xff0c;大学对于大学生毕业设计越来越重视。 做软件设计设计方面&#xff0c;前后端分离是必不可少的&#xff0c;代码管理工具&#xff0c;前后端接口测试是项目中必须要用到的工具。做大数据设计方面&#xff0c;主要是要用到爬虫进行数据爬取&…

yum下载安装包

一、背景 对于连接网络的centos系统&#xff0c;可以直接通过yum install安装应用。 对于不能连接外部网络的centos系统&#xff0c;显然yum无法使用&#xff0c;需要将安装包拷贝到机器上安装&#xff0c;但去哪里去寻找和下载安装包呢。 二、yum downloads yum工具贴心的…

【数据分析面试】36.SAAS公司邮件营销策略分析(业务分析)

题目 假设你在一个B2B SAAS公司营销团队工作。本季度即将结束&#xff0c;但当前收入距离预期目标还差10%。营销团队的一个高管要求负责电子邮件营销的人向所有客户群发邮件&#xff0c;要求他们购买更多产品。这是个好主意吗&#xff1f;为什么&#xff1f; 提示1&#xff1…

[论文笔记]Longformer: The Long-Document Transformer

引言 今天带来论文Longformer: The Long-Document Transformer的笔记。 基于Transformer的模型由于其自注意力操作而无法处理长序列&#xff0c;该操作随着序列长度呈二次扩展。为了解决这一限制&#xff0c;本篇工作提出了Longformer&#xff0c;其注意力机制随着序列长度呈…