栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java 利用递归实现链表的归并排序

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java 利用递归实现链表的归并排序

利用归并排序,我们可以将时间复杂度降至O(nlogn), 并且我们是对链表进行排序,可以通过修改引用来更改节点顺序,无需像数组一样开辟而外的空间。

利用递归实现链表的归并排序有两个环节:

分割cut环节:

我们可以利用fast, slow快慢双指针实现链表的分割, fast一次移动两位, slow一次移动一位,当fast移动到末尾时,slow移动到中间位置。

利用变量为tmp = slow.next记录后链表的头节点,并将slow.next = null将前后链表断开。

ListNode sortList(ListNode head) {
 if (head == null || head.next == null)
  return head;
 
 ListNode fast = head.next, slow = head;
 while (fast != null && fast.next != null) {
  fast = fast.next.next; // 一次移动两位
  slow = slow.next; // 一次移动一位
 }
 
 ListNode tmp = slow.next; // 记录后链表的头节点
 slow.next = null; // 将前后链表断开
 //...
}

cut递归的终止条件 base case 为当head.next == null,即链表只有一个节点。

归并merge环节:

使用辅助指针,将前后链表后合并为一个有序链表

ListNode sortList(ListNode head) {
 //...
 // left 为前链表的头节点, right 为后链表的头节点, h 为辅助节点
 while (left != null && right != null) {
  if (left.val < right.val) { 
   h.next = left;
   left = left.next;
  } else {
   h.next = right;
   right = right.next;
  }
  h = h.next;
 }
 h.next = left != null ? left : right;
 //...
}

明白上面的两个环节后,就能轻松明白我们完整的算法了。

ListNode sortList(ListNode head) {
    if (head == null || head.next ==null)
      return head;
    // cut过程
    ListNode fast = head.next, slow = head;
    while (fast != null && fast.next != null) {
      fast = fast.next.next;
      slow = slow.next;
    }
    ListNode tmp = slow.next;
    slow.next = null;
	// merage过程
    ListNode left = sortList(head);
    ListNode right = sortList(tmp);
    ListNode h = new ListNode(0);
    ListNode res = h;
    while (left != null && right != null) {
      if (left.val < right.val) {
 h.next = left;
 left = left.next;
      } else {
 h.next = right;
 right = right.next;
      }
      h = h.next;
    }
    h.next = left != null ? left : right;

    return res.next;
  }

以上就是Java 利用递归实现链表的归并排序的详细内容,更多关于Java 链表排序的资料请关注考高分网其它相关文章!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/131819.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号