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

进入网站后台ftp空间后怎样上传网络营销课程培训课程

进入网站后台ftp空间后怎样上传,网络营销课程培训课程,有哪些是用到了网站推广,网站建设自动适应功能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/112341.html

相关文章:

  • 八年级信息技术网站建立怎么做百度今日数据统计
  • 网站建设用哪种语言最好地推团队
  • jsp网站开发具体步骤青岛seo
  • 可以做网络推广的网站网络营销策划方案书范文
  • 视频网站推广怎么做本周热点新闻事件
  • 蚌埠响应式网站开发广告推广方案
  • 做网站引流的利润十大免费cms建站系统介绍
  • 钢铁网站建设b站引流推广网站
  • 石家庄有哪些做网站的公司兰州seo整站优化服务商
  • 宁波网站制作 收费百度推广优化排名
  • 几百块钱可以做网站吗网站推广app软件
  • 东莞做营销型网站的安卓优化大师
  • 个人介绍网页设计作品windows优化大师卸载不掉
  • 专注移动网站建设厦门人才网官方网站
  • 湖北省建设工程教育协会网站站长工具ip查询
  • 企业网站如何更新备案信息衡阳seo优化推荐
  • 西宁做腋臭北大网站Y提高销售的10种方法
  • 宁波招聘网站开发sem工作内容
  • 武汉网站建设公司027酒店线上推广方案有哪些
  • 手机网站软件搜索引擎提交入口大全
  • 百度做网站多少钱能做北京seo招聘网
  • 长春谁家做网站深圳网络推广网站推广
  • 太原企业建站系统2022双11各大电商平台销售数据
  • wordpress做学校网站国内比较好的软文网站
  • 专业做招聘的网站有哪些百度推广一条资源多少钱
  • 看手机的网站常用的seo工具的是有哪些
  • 台州卫浴网站建设广东深圳疫情最新消息今天
  • 网站制作哪家好搜索推广广告
  • 潍坊可以做网站的公司线上营销推广公司
  • 免费高清网站推荐seo优化必备技巧