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

哪些网站做外贸哈尔滨专业官网建站企业

哪些网站做外贸,哈尔滨专业官网建站企业,网上教育培训机构,做网站导航的Day 76 题目描述思路 初次思路:题目进阶要求O(nlogn)的时间复杂度,但这类排序算法对于链表难以实现,所以我先选择了使用选择排序入手,具体做法如下: 使用快慢指针遍历链表,beg指针记录已排序的位置&#xf…

Day 76

题目描述

在这里插入图片描述

思路

初次思路:题目进阶要求O(nlogn)的时间复杂度,但这类排序算法对于链表难以实现,所以我先选择了使用选择排序入手,具体做法如下:

  1. 使用快慢指针遍历链表,beg指针记录已排序的位置,min和bemin记录这一轮最小节点及其前一个节点
  2. 如果beg的下一个不是空,说明没有遍历完所有链表
  3. 使用快慢指针顺序遍历,比较fast指向值和min比较,比它小记录fast和slow指针
  4. 遍历一轮结束后,进行交换即可
/**1. Definition for singly-linked list.2. public class ListNode {3.     int val;4.     ListNode next;5.     ListNode() {}6.     ListNode(int val) { this.val = val; }7.     ListNode(int val, ListNode next) { this.val = val; this.next = next; }8. }*/
class Solution {public ListNode sortList(ListNode head) {if(head==null){return head;}ListNode m=new ListNode();m.next=head;ListNode beg=m;ListNode slow=m;//慢指针ListNode fast=m.next;//快指针ListNode min=m.next;ListNode bemin=m;while(beg.next!=null){int mins=50001;while(fast!=null){if(fast.val<mins){mins=fast.val;min=fast;bemin=slow;}slow=slow.next;fast=fast.next;}//取到这一轮最小的值了bemin.next=min.next;min.next=beg.next;beg.next=min;beg=beg.next;slow=beg;fast=slow.next;}return m.next;}}

可惜超时了
在这里插入图片描述
分析一下,还是选择排序太慢了 O(n方),所以还是得从那几个O(nlogn)的算法入手
优化思路:我们可以采取归并排序的方式来解决这个问题

  1. 将链表不断分为左右两段,分离的函数为 getMiddle(ListNode head),做法不赘述了,前面的题目实现过。
  2. 最后链表会分为一段只有一个数字(分割的最终阶段)
  3. 开始合并,合并算法是归并算法(前面也做过)
  4. 最后合并成一个有序链表
/*** Definition for singly-linked list.* public class ListNode {*     int val;*     ListNode next;*     ListNode() {}*     ListNode(int val) { this.val = val; }*     ListNode(int val, ListNode next) { this.val = val; this.next = next; }* }*/
class Solution {public ListNode sortList(ListNode head) {// 递归终止条件if (head == null || head.next == null) {return head;}// 找到中间节点并分割链表ListNode mid = getMiddle(head);ListNode rightHead = mid.next;mid.next = null; // 断开左右链表// 递归排序左右两部分ListNode left = sortList(head);ListNode right = sortList(rightHead);// 合并有序链表return merge(left, right);}// 使用快慢指针找到链表的中间节点private ListNode getMiddle(ListNode head) {if (head == null) return null;ListNode slow = head;ListNode fast = head.next;while (fast != null && fast.next != null) {slow = slow.next;fast = fast.next.next;}return slow;}// 合并两个有序链表private ListNode merge(ListNode l1, ListNode l2) {if (l1 == null) return l2;if (l2 == null) return l1;ListNode dummy = new ListNode(0);ListNode tail = dummy;while (l1 != null && l2 != null) {if (l1.val < l2.val) {tail.next = l1;l1 = l1.next;} else {tail.next = l2;l2 = l2.next;}tail = tail.next;}// 处理剩余节点if (l1 != null) tail.next = l1;if (l2 != null) tail.next = l2;return dummy.next;}
}
http://www.dtcms.com/a/436837.html

相关文章:

  • 怎么用vs2008做网站全渠道营销成功案例
  • 自己写小说的网站网站开发方式的选择
  • 湖南建设网站官网网站制作背景图片
  • 有哪些做h5的网站wonder audio wordpress
  • 南昌电影网站开发足球世界排名国家最新
  • 无网站做cpa网站服务器如何选择
  • 苏州吴江做网站有一个可以做任务的网站
  • 浙江交工宏途交通建设有限公司网站南阳美容网站建设
  • 重庆网站建设大概需要多少钱全新升级网站
  • 橙域名网站wordpress显示注册按钮
  • 企业网站建设工作流程大企业宣传片
  • 小企业做网站有用吗三合一网站怎么做
  • 网站建设询价文件卖信息的网站
  • 用自己的手机做网站房地产最新消息14号公告
  • 温州网站建设seowordpress 生成主题包
  • 做设计用图片的网站3d建模怎么做
  • 一键免费生成网页的网站免费数据查询网站
  • 石龙网站仿做网站导航栏全屏怎么做的
  • 装潢建筑公司网站设计企业网站管理系统项目文档
  • 网站规划开发前景电子工程师社区
  • 网站建设实录音乐365房产网
  • 公司网站页面加密晋中建设机械网站
  • 【LaTeX】 7 LaTeX 图片插入与定位
  • 义乌网站建设公司价位网络精准推广
  • 企业网站备案怎么填写室内设计网站排行榜前十名知乎
  • php 微网站开发潍坊网站制作网络科技
  • 网站开发投标书范本目录1 建设网站目的
  • 网站一键备案大气家具营销型网站源码
  • 网站建设留言板实验心得深圳市宝安区做网站建设的企业
  • 百度网站优化 件用dw做的个人网站