我用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实现

LeetCode147.对链表进行插入排序(Python)

LeetCode Algorithm 147. 对链表进行插入排序

LeetCode Algorithm 147. 对链表进行插入排序

LeetCode147.对链表进行插入排序(Python)

LeetCode--147.对链表进行插入排序