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

建站网站怎么上传代码东莞做网站公司

建站网站怎么上传代码,东莞做网站公司,网络广告网站怎么做,静安企业网站建设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/wzjs/261066.html

相关文章:

  • 苏州网站地址美国搜索引擎
  • 江苏国龙翔建设网站seo技术优化整站
  • 佛山微网站建设 天博优化网站推广排名
  • 网站备案丢失百度app下载官方免费最新版
  • 重庆集团公司网站建设怎么在百度上发布个人文章
  • 建设银行手机官方网站下载海淀区seo搜索引擎
  • 制作asp手机网站长沙seo步骤
  • 做自己视频教程的网站百度seo报价
  • 南山区做网站公司免费推广网站平台
  • 西宁公司网站设计chrome谷歌浏览器
  • 旅游网站建设项目规划书企业网站建设规划
  • javaweb源码免费分享网站网站运营推广
  • 江苏网站建设效果中国国家培训网是真的吗
  • 服务器怎样建设网站友情链接的方式如何选择
  • 网站底色什么颜色好看郑州网站优化公司
  • 在线制作电子简历合肥百度快速排名优化
  • 企业网站本身应该就是企业( )的一部分seo关键词怎么填
  • 泰康人寿保险官方网站查排名网站
  • 软件工程 旅游网站开发er图谷歌搜索为什么用不了
  • wordpress小论坛seo网络贸易网站推广
  • 做系统网站信息检索网站湖北seo关键词排名优化软件
  • 安徽网站建设天锐科技推广网络公司
  • 网站商务通客服端友链交换平台源码
  • vue做的小网站外贸网站制作推广
  • 天津做网站找津坤科技专业武汉百度关键词推广
  • iis如何做网站管理器seo推广软件下载
  • 开源手机网站系统免费推广平台有哪些
  • xp怎么做网站服务器长沙网
  • 在线长图生成器南昌seo计费管理
  • 平面广告设计要用什么软件有哪些深圳seo推广外包