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

淘宝网站建设弄什么类目用vs做网站表格向上居中

淘宝网站建设弄什么类目,用vs做网站表格向上居中,泉州做网站的企业,陕西省建设工程质量监督站网站148. 排序链表 题目:给你链表的头结点 head ,请将其按升序排列并返回排序后的链表。 题目链接: 148. 排序链表 时间复杂度:快排 O(n^2) 超出时间限制 class Solution {public ListNode sortList(ListNode head) {if(headnull)…

148. 排序链表

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

题目链接: 148. 排序链表
时间复杂度:快排 O(n^2) 超出时间限制

class Solution {public ListNode sortList(ListNode head) {if(head==null){return head;}ListNode dummy=new ListNode(Integer.MIN_VALUE,null);ListNode pointnew=dummy;ListNode pointold=head;while(pointold!=null){while(pointnew!=null&&pointnew.next!=null){if(pointold.val<=pointnew.next.val){ListNode next=pointnew.next;ListNode node=new ListNode(pointold.val);pointnew.next=node;node.next=next;pointnew=dummy;break;}else{pointnew=pointnew.next;}}if(pointnew.next==null){ListNode next=pointnew.next;ListNode node=new ListNode(pointold.val);pointnew.next=node;node.next=next;pointnew=dummy;}pointold=pointold.next;}return dummy.next;}
}

归并排序O(logn):

class Solution {public ListNode sortList(ListNode head) {if(head==null||head.next==null){return head;}//找中点截断链表ListNode fast = head;ListNode slow = head;ListNode pre=null;while(fast!=null&&fast.next!=null){pre=slow;slow=slow.next;fast=fast.next.next;}//递归截断链表pre.next=null;ListNode left=sortList(head);ListNode right=sortList(slow);//合并链表ListNode dummy=new ListNode(0);ListNode res = dummy;while (left != null && right != null) {if (left.val < right.val) {res.next = left;left = left.next;} else {res.next = right;right = right.next;}res=res.next;}res.next=left!=null?left:right;return dummy.next;}
}

归并排序迭代方法 时间复杂度O(logn),空间复杂度为O(1):
直接当作n个长度为1的链表进行归并 先归并为2个有序,继而4,8…直到其长度大于链表长度n

public ListNode sortList(ListNode head) {if (head == null || head.next == null) {return head;}// 获取链表长度int length = 0;ListNode current = head;while (current != null) {length++;current = current.next;}ListNode dummy = new ListNode(0);dummy.next = head;ListNode left, right, tail;// 每次翻倍增加子链表的长度for (int step = 1; step < length; step *= 2) {current = dummy.next;tail = dummy;while (current != null) {left = current;right = split(left, step); // 分割出两个子链表current = split(right, step); //划分下一个lefttail = merge(left, right, tail); // 合并两个子链表}}return dummy.next;}// 分割链表private ListNode split(ListNode head, int step) {if (head == null) return null;for (int i = 1; head.next != null && i < step; i++) {head = head.next;}ListNode right = head.next;head.next = null;return right;}// 合并两个链表private ListNode merge(ListNode l1, ListNode l2, ListNode tail) {ListNode current = tail;while (l1 != null && l2 != null) {if (l1.val < l2.val) {current.next = l1;l1 = l1.next;} else {current.next = l2;l2 = l2.next;}current = current.next;}current.next = (l1 != null) ? l1 : l2;while (current.next != null) {current = current.next;}return current;}
http://www.yayakq.cn/news/724663/

相关文章:

  • 主题商店网站设计移动网站mip
  • 粉红色主题 模板 网站 在线预览聊城手机网站公司电话
  • 工作室 网站经营性备案软件应用技术学什么
  • 快速赢在互联网+营销时代徐州网站建设商城制作网站推广seo
  • 四川住房和城乡建设九大员网站新网站没有死链接怎么做
  • 宁波网站建设哪家好怎么利用wordpress管理站点
  • 企业网站建设方案流程网站建设可用性的五个标准
  • 做网站怎么备份数据重庆大型网络公司
  • 营销型网站一个多少钱网站备案 两个域名
  • 玉林网站推广品牌买购网
  • 中国建设银行手机版网站首页淘客推广个人网站怎么做
  • 开发手机网站用什么语言做的比较好的猎头网站
  • 网站建设华网天下制作作网络销售怎么做才能做好
  • 做印刷厂网站低俗网站推广哪里找
  • 仿站网站域名国产长尾关键词拘挖掘
  • 文山seo对seo的理解
  • 网站上不去的原因做图片的软件
  • 嘉兴做外贸网站的公司一键生成ppt
  • windows 2003 取消网站访问密码网销怎么找客户资源
  • 石家庄高端网站开发90设计app下载
  • 建设网站收取广告费用定制微信免费下载
  • 翠峦网站建设淘客怎么做推广网站
  • 网站策划书市场分析烟台网站建设找三硕科技
  • 象山专业网站建设大气wordpress主题
  • 山网站建设做个网上平台大概要多少钱
  • wordpress新建网站后台无法登陆画册设计一般用什么软件
  • 公司想做一个网站哪里做企业网站
  • 网站策划书网站需求分析wordpress 文章 字体
  • 除了亚马逊还有啥网站做海淘张家界旅游
  • 湛江有网站的公司名称wordpress怎么搜索中文主题