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

公司网站模板下载专门看网站的浏览器

公司网站模板下载,专门看网站的浏览器,网站上传空间的ip地址吗,中国十大咨询公司LeetCode:排序链表 一、题目描述 给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表 。 二、分析 这题咱们默认要求:空间复杂度为O(1)。所以这把咱们用自底向上的方法实现归并排序,则可以达到O(1) 的空间复杂…

LeetCode:排序链表

一、题目描述

给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、分析

这题咱们默认要求:空间复杂度为O(1)。所以这把咱们用自底向上的方法实现归并排序,则可以达到O(1) 的空间复杂度。

具体算法如下:

1、首先,判断如果所给的 head 为 null 则返回null
2、求出所给链表head的长度length,然后将链表拆分成子链表进行合并。具体算法如下:

  • 2.1、用subLen表示每次需要排序的子链表的长度,初始值subLen为1.
  • 2.2、每次将链表拆分成若干个长度为subLen的子链表(最后一个子链表的长度可以小于subLen),按照每两个子链表一组进行合并(通过使用合并两个有序链表的做法),合并后即可得到若干个长度为 subLen2 的有序子链表(最后一个子链表的长度可以小于 subLen2)。合并两个子链表仍然使用合并两个有序链表的做法。
  • 2.3、将subLen的值加倍(通过位运算左移1位的方式),重复第2步,对更长的有序子链表进行合并操作,直到有序子链表的长度大于或等于length,整个链表排序完毕。

如何保证每次合并后得到的子链表都是有序的呢?可以通过数学归纳法证明。

  • 1、初始时subLen为1,每个长度为1的子链表都是有序的

  • 2、如果每个长度为subLen的子链表已经有序,那么合并两个长度为subLen的子链表后,得到长度为subLen * 2
    的子链表,一定也是有序的。

  • 3、当最后一个子链表的长度小于subLen时,该子链表也是有序的,合并两个链表之后得到的子链表一定也是有序的。

三、上代码

public class Deal11 {public ListNode sortList(ListNode head) {if (head == null) {return null;}//1、从头向后遍历链表,统计链表长度int length = 0;ListNode p = head;while(p != null) {length++;p=p.next;}//2、设定result用于记录最终返回结果,并对其进行最终的初始化ListNode result = new ListNode(-1);result.next = head;//3、将链表拆分成若干个长度为subLen的子链表,并按照没两个子链表一组进行合并for (int subLen = 1; subLen < length; subLen <<= 1) {//将subLen的值加倍(通过位运算左移1位的方式)ListNode pre = result;ListNode cur = result.next;   //用于记录拆分链表的位置while (cur != null) { //如果链表没有被拆完//3.1 拆分出链表1,其长度为subLenListNode head_1 = cur;    //第一个链表的头,即curfor (int i = 1; i < subLen && cur != null && cur.next != null; i++) {cur = cur.next;}//3.2 拆分出链表2,其长度也为subLenListNode head_2 = cur.next; //第二个链表的头,即第一个链表尾部的下一个位置cur.next = null; //断开第一个链表和第二个链表的连接cur = head_2;    //第二个链表的头重新赋给curfor (int i = 1; i < subLen && cur != null && cur.next != null; i++) {cur = cur.next;}//3.3 再次断开第二个链表的的连接ListNode next = null;if (cur != null) {next = cur.next;  //用于记录拆分完两个链表后结束的后序位置cur.next = null;}//3.4 合并两个有序链表head_1 和 head_2ListNode merge = mergeTwo(head_1, head_2);pre.next = merge;while (pre.next != null) {pre = pre.next;}cur = next;}}return result.next;}//合并两个有序链表public ListNode mergeTwo(ListNode head1, ListNode head2) {ListNode result = new ListNode(-1);ListNode p = result;ListNode p1 = head1;ListNode p2 = head2;while(p1 != null && p2 != null) {if (p1.val > p2.val) {p.next = p2;p2 = p2.next;} else {p.next = p1;p1 = p1.next;}p = p.next;}if (p1 == null) {p.next = p2;}if (p2 == null) {p.next = p1;}return result.next;}
}
http://www.15wanjia.com/news/158334.html

相关文章:

  • 大学网站开发模板免费下载网络推广营销
  • 怎么查网站的所有权开发公司专票
  • 做网络销售怎么建立网站seo查询百科
  • 政务服务 网站 建设方案宜昌本地网站
  • 宁波鄞州网站建设二手房网签合同在哪个网站做
  • 宁波建网站报价h5个人网站模板
  • 唐山免费自助建站模板上海家装设计网站
  • 网站建设预算模板wordpress 启用插件代码
  • 网站设计建议wordpress无法添加小工具
  • 购物网站建设需要注意什么黄石网站建设教程
  • 南京做公司网站的公司哪家好市场推广是做什么的
  • 有谁想做网站 优帮云推广策略
  • 电子商务网站开发实训体会wordpress 教程主题
  • 做图专业软件下载网站公司做网站的法律依据
  • dede 网站地图模版做旅游网站的目的和意义
  • 免费企业网站源码看片狂人
  • 企业营销网站建设公司网络营销的途径有哪些
  • 做平台的网站有哪些内容吗响应式网站建设推荐乐云践新
  • 网站建设功能需求分析网站建设完成后怎么上传服务器
  • 免费建造公司网站中国建设银行登录官网
  • 手机版网站优化阳江网雨大精神病专科医院
  • 自己做的网站怎么挂网上浏览wap网站
  • 网站运营怎样做百度装修网站
  • 小型电子商务网站开发做钢化膜网站
  • 广州货运网站建设官方网站建设案例
  • 帮忙做快站旅游网站怎么免费做公司网站
  • 网站建设与管理书籍wordpress域名更换插件
  • 怎样增加网站流量做公司网站的
  • 凡客网能直接做网站北京定制网站建设公司
  • 温岭市市住房和城乡建设规划局网站网络认证入口