leetcode148-Sort List

题目

给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表 。

示例 1:

输入:head = [4,2,1,3]

输出:[1,2,3,4]

分析

这道题目的思路也比较明确,我们可以用递归排序的思路,先不断拆分链表直到只剩下一个结点,然后再合并俩个有序列表。拆分链表可以用快慢指针的方法

java 复制代码
public class LinkNode {
	int val;
	LinkNode next;

	public LinkNode(int data) {
		this.val = data;
		this.next = null;
	}
}
public class LinkList {
	LinkNode head;
	public LinkList() {
		this.head = null;
	}
	public LinkNode getHead() {
		return this.head;
	}
	//添加元素
	public void addNode(int data) {
		LinkNode node = new LinkNode(data);
		if (this.head == null) {
			this.head = node;
		} else {
			LinkNode cur = this.head;
			while(cur.next != null) {
				cur = cur.next;
			}
			cur.next = node;
		}
	}
	//正序打印
	public void print(LinkNode node) {
		while(node != null) {
			System.out.print(node.val);
			System.out.print(" ");
			node = node.next;
		}
		System.out.println();
	}
	public LinkNode sort(LinkNode head) {
		if(head == null || head.next == null) {
			return head;
		}
		LinkNode fast = head;
		LinkNode slow = head;
		LinkNode pre = null;
		while(fast != null && fast.next != null) {
			pre = slow;
			slow = slow.next;
			fast = fast.next.next;
		}
		pre.next = null;
		return merge(sort(slow),sort(head));
	}
	public LinkNode merge(LinkNode slow,LinkNode fast) {
		LinkNode dummy = new LinkNode(0);
		LinkNode p = dummy;
		while(slow != null && fast != null) {
			if(slow.val < fast.val) {
				p.next = slow;
				p = p.next;
				slow = slow.next;
			} else {
				p.next = fast;
				p = p.next;
				fast = fast.next;
			}
		}
		while(slow != null) {
			p.next = slow;
			p = p.next;
			slow = slow.next;
		}
		while(fast != null) {
			p.next = fast;
			p = p.next;
			fast = fast.next;
		}
		return dummy.next;
	}
}
public class sortList {
	public static void main(String[] args) {
		LinkList list = new LinkList();
		list.addNode(-1);
		list.addNode(5);
		list.addNode(3);
		list.addNode(4);
		list.addNode(0);
		LinkNode head = list.sort(list.getHead());
		list.print(head);
	}
}
相关推荐
半兽先生15 分钟前
WebRtc 视频流卡顿黑屏解决方案
java·前端·webrtc
南星沐1 小时前
Spring Boot 常用依赖介绍
java·前端·spring boot
勤劳的进取家2 小时前
贪心算法之最小生成树问题
数据结构·python·算法·贪心算法·排序算法·动态规划
代码不停2 小时前
Java中的异常
java·开发语言
牛奶咖啡.8542 小时前
第十四届蓝桥杯大赛软件赛省赛C/C++ 大学 A 组真题
c语言·数据结构·c++·算法·蓝桥杯
小美爱刷题2 小时前
力扣DAY46-50 | 热100 | 二叉树:展开为链表、pre+inorder构建、路径总和、最近公共祖先、最大路径和
算法·leetcode·链表
何似在人间5753 小时前
多级缓存模型设计
java·jvm·redis·缓存
多云的夏天3 小时前
ubuntu24.04-MyEclipse的项目导入到 IDEA中
java·intellij-idea·myeclipse
Fanxt_Ja3 小时前
【数据结构】红黑树超详解 ---一篇通关红黑树原理(含源码解析+动态构建红黑树)
java·数据结构·算法·红黑树
Aphelios3803 小时前
TaskFlow开发日记 #1 - 原生JS实现智能Todo组件
java·开发语言·前端·javascript·ecmascript·todo