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);
	}
}
相关推荐
历程里程碑几秒前
C++ 8:list容器详解与实战指南
c语言·开发语言·数据库·c++·windows·笔记·list
骚戴4 分钟前
架构设计之道:构建高可用的大语言模型(LLM) Enterprise GenAI Gateway
java·人工智能·架构·大模型·gateway·api
TH_15 分钟前
7、在线接口文档沟通
java
Silence_Jy5 分钟前
cs336Lecture 5 and7
java·redis·缓存
程序员祥云10 分钟前
技能特⻓回答
前端·面试
周杰伦_Jay12 分钟前
【后端开发语言对比】Java、Python、Go语言对比及开发框架全解析
java·python·golang
计算机毕设指导615 分钟前
基于微信小程序的网络安全知识科普平台系统【源码文末联系】
java·spring boot·安全·web安全·微信小程序·小程序·tomcat
while(1){yan}23 分钟前
网络编程UDP
java·开发语言·网络·网络协议·青少年编程·udp·电脑常识
古城小栈27 分钟前
边缘计算:K3s 轻量级 K8s 部署实践
java·kubernetes·边缘计算
武子康27 分钟前
Java-196 消息队列选型:RabbitMQ vs RocketMQ vs Kafka
java·分布式·kafka·rabbitmq·rocketmq·java-rocketmq·java-rabbitmq