力扣hot100 排序链表 归并排序 递归

Problem: 148. 排序链表

在这里插入图片描述

👩‍🏫 参考

💖 归并排序(递归)

⏰ 时间复杂度: O ( n ) O(n) O(n)
🌎 空间复杂度: O ( n ) O(n) O(n)
在这里插入图片描述

/**
 * 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 fast = head.next;
		ListNode slow = head;
		while (fast != null && fast.next != null)
		{
			slow = slow.next;
			fast = fast.next.next;
		}
		ListNode second = slow.next;
		slow.next = null;// 断开前后两段的联系
		ListNode left = sortList(head);
		ListNode right = sortList(second);
		ListNode h = new ListNode(0);
		ListNode dummy = 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 dummy.next;
	}
}

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-01-26 02:42:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-26 02:42:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-26 02:42:01       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-26 02:42:01       20 阅读

热门阅读

  1. JNI中获取当前时间戳

    2024-01-26 02:42:01       31 阅读
  2. 【docker】之基础篇二

    2024-01-26 02:42:01       33 阅读
  3. vue router 右到左过渡动画

    2024-01-26 02:42:01       35 阅读
  4. 蓝桥杯基础准备2

    2024-01-26 02:42:01       39 阅读