我用java刷 leetcode 147. 对链表进行插入排序
Posted 深林无鹿
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了我用java刷 leetcode 147. 对链表进行插入排序相关的知识,希望对你有一定的参考价值。
这里有leetcode题集分类整理!!!
题目难度: 中等
题目描述:
对链表进行插入排序。
插入排序算法:
插入排序是迭代的,每次只移动一个元素,直到所有元素可以形成一个有序的输出列表。
每次迭代中,插入排序只从输入数据中移除一个待排序的元素,找到它在序列中适当的位置,并将其插入。
重复直到所有输入数据插入完为止。
示例 1:
输入: 4->2->1->3
输出: 1->2->3->4
示例 2:
输入: -1->5->3->4->0
输出: -1->0->3->4->5
官方思路:
根据解题思路 AC :
/**
* 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 insertionSortList(ListNode head) {
if (head == null) return head;
ListNode dummyHead = new ListNode(0);
dummyHead.next = head;
ListNode lastSorted = head;
ListNode curr = lastSorted.next;
while (curr != null) {
if (lastSorted.val <= curr.val) {
lastSorted = lastSorted.next;
} else {
ListNode prev = dummyHead;
while (prev.next.val <= curr.val) {
prev = prev.next;
}
lastSorted.next = curr.next;
curr.next = prev.next;
prev.next = curr;
}
curr = lastSorted.next;
}
return dummyHead.next;
}
}
我的麻烦AC:
/**
* 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 insertionSortList(ListNode head) {
if (head == null) return head;
ListNode dummyHead = new ListNode(0);
List<Integer> list = new ArrayList<>();
setList(list, head);
Collections.sort(list);
ListNode curr = dummyHead;
for (int value : list) {
ListNode newNode = new ListNode(value);
curr.next = newNode;
curr = curr.next;
}
curr.next = null ;
return dummyHead.next;
}
public void setList(List<Integer> list, ListNode node) {
while (node != null) {
list.add(node.val);
node = node.next;
}
}
}
以上是关于我用java刷 leetcode 147. 对链表进行插入排序的主要内容,如果未能解决你的问题,请参考以下文章
LeetCode第147题—对链表进行插入排序—Python实现
LeetCode Algorithm 147. 对链表进行插入排序