【leetcode】148. Sort List

news/2024/7/8 0:18:20

Sort a linked list in O(n log n) time using constant space complexity.

 链表排序可以用很多方法,插入,冒泡,选择都可以,也容易实现,但是复杂度不符合题意要求。

然后时间复杂度在O(nlogn)的排序算法中,堆排序,快速排序,归并排序。

  • 堆排序,主要是基于数组的,这里是链表,实现起来比较麻烦。
  • 快速排序,快速排序最坏情况的时间复杂度是O(n2)
  • 归并排序,在对数组的归并排序中,是有O(n)的空间复杂度的,但是链表可以不需要,我们可以用构造虚拟节点法

就地合并两个有序链表。

因此,我们就选择用归并排序来解决这道题,合并两个有序链表将作为链表常见算法题之一,在算法总结那篇文章中会出现。

归并的核心思想就是divide-merge。如何divide,又涉及到链表常见算法——找到中间节点。找到中间节点后,即可把链表

划分成两个链表,然后再合并。

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution {
public:ListNode* sortList(ListNode* head) {if(head==NULL||head->next==NULL)return head;return MergeSort(head);}
/*    ListNode* Merge(ListNode* r,ListNode* l){if(r==NULL||l==NULL)return r?r:l;ListNode*p,*q;if(r->val<l->val){p=r;q=l;}else{p=l;q=r;}ListNode head=p;ListNode* tmp=r;ListNode* bf=p;while(p&&q){if(p->val<q->val){bf=p;p=p->next;}else{tmp=q;q=q->next;bf->next=tmp;}}if(!q){bf->next=q;}return head;}*/ListNode * Merge(ListNode *lh, ListNode *rh){ListNode *temp=new ListNode(0);ListNode *p=temp;while(lh&&rh){if(lh->val<=rh->val){p->next=lh;lh=lh->next;}else{p->next=rh;rh=rh->next;}p=p->next;}if(!lh)p->next=rh;elsep->next=lh;p=temp->next;temp->next=NULL;delete temp;return p;}ListNode* MergeSort(ListNode* head){if(head==NULL||head->next==NULL)return head;ListNode* p=head;ListNode* middle=head,*pre=NULL;;while(p&&p->next!=NULL){p=p->next->next;pre=middle;middle=middle->next;}pre->next=NULL;head=MergeSort(head);middle=MergeSort(middle);return Merge(head,middle);}
};

 

转载于:https://www.cnblogs.com/LUO77/p/5666587.html


http://lihuaxi.xjx100.cn/news/284454.html

相关文章

南开大学提出目标检测新Backbone网络模块:Res2Net | 技术头条

点击上方↑↑↑蓝字关注我们~「2019 Python开发者日」&#xff0c;购票请扫码咨询 ↑↑↑作者 | 高尚华、程明明等&#xff08;南开大学&#xff09;译者 | 刘畅编辑 | Jane出品 | AI科技大本营&#xff08;id&#xff1a;rgznai100&#xff09;【导读】去年&#xff0c;AI科技…

GCC 参数列举及解释

GCC(GNU Compiler Collection&#xff0c;GNU编译器套件)&#xff0c;是由 GNU 开发的编程语言编译器。它是以GPL许可证所发行的自由软件&#xff0c;也是 GNU计划的关键部分。gcc 与 g 分别是 gnu 的 c & c 编译器 gcc/g 在执行编译工作的时候&#xff0c;总共需要4步&…

最优秀的人都在学数学,这就是法国数学如此强大的原因!

一、引子在德国数学家高斯的一部传记中&#xff0c;作者引用了下面这段话&#xff1a;有一个异乡人在巴黎问当地人&#xff0c;“为什么贵国历史上出了那么多伟大的数学家&#xff1f;”巴黎人回答&#xff0c;“我们最优秀的人学习数学。”又去问法国数学家&#xff0c;“为什…

Java性能调优、LinkedIn容器部署、阿里移动性能调优——首届APMCon精彩演讲先睹为快...

APMCon2016&#xff0c;在盛夏的8月等你。\\作为第一届APM垂直领域的技术大会&#xff0c;我们能拿出什么呈现给参会者&#xff1f;\\答案是&#xff0c;除了会场可以纳凉避暑之外&#xff0c;还有来自国内外顶级技术大拿带来的Java性能管理、容器部署管理、移动性能管理等最前…

全球人工智能应用创新峰会如期而至,4月9日,深圳见!

人工智能的浪潮席卷全球&#xff0c;随着新的人工智能应用场景不断涌现&#xff0c;技术突破和应用加速落地不断被探讨。人工智能在智慧城市、智慧工业等布局不断加深&#xff0c;加速各行业深度融合&#xff0c;促进经济发展, 推动社会各领域从数字化、网络化向智能化加速跃升…

区分Java拦截器和过滤器

今天带大家分析java拦截器和过滤器的区别,文中有非常详细的解释说明,对正在学习java的小伙伴们有很好的帮助,需要的朋友可以参考下 一、过滤器&#xff08;filter&#xff09; 过滤器处于客户端与Web资源&#xff08;Servlet、JSP、HTML&#xff09;之间&#xff0c;客户端与W…

Linux命令(基础)

2019独角兽企业重金招聘Python工程师标准>>> 基本命令 ###关机 poweroff shutdown -h nowreboot shutdown -r now #重启查看当前目录占用磁盘空间大小 du -sh# -h&#xff1a;以人类可读的方式显示 #  -a&#xff1a;显示目录占用的磁盘空间大小&#xff0…

仅用语音,AI就能“脑补”你的脸! | 技术头条

点击上方↑↑↑蓝字关注我们~「2019 Python开发者日」&#xff0c;购票请扫码咨询 ↑↑↑作者 | Wav2pix 研究团队译者 | 刘畅编辑 | Jane出品 | AI科技大本营&#xff08;公众号id&#xff1a;rgznai100&#xff09;【导语】之前我们为大家介绍过一项非常酸爽的研究“Talking…