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);
	}
}
相关推荐
青い月の魔女5 分钟前
数据结构初阶---二叉树
c语言·数据结构·笔记·学习·算法
一个不秃头的 程序员9 分钟前
代码加入SFTP JAVA ---(小白篇3)
java·python·github
丁总学Java21 分钟前
--spring.profiles.active=prod
java·spring
上等猿28 分钟前
集合stream
java
我要出家当道士30 分钟前
Nginx单向链表 ngx_list_t
数据结构·nginx·链表·c
java1234_小锋32 分钟前
MyBatis如何处理延迟加载?
java·开发语言
菠萝咕噜肉i33 分钟前
MyBatis是什么?为什么有全自动ORM框架还是MyBatis比较受欢迎?
java·mybatis·框架·半自动
林的快手1 小时前
209.长度最小的子数组
java·数据结构·数据库·python·算法·leetcode
从以前1 小时前
准备考试:解决大学入学考试问题
数据结构·python·算法
向阳12181 小时前
mybatis 缓存
java·缓存·mybatis