【LeetCode147】对链表进行插入排序

简介: The number of nodes in the list is in the range [1, 5000].-5000 <= Node.val <= 5000二、思路

一、对链表进行插入排序

image.png

栗子:

image.png

Input: head = [-1,5,3,4,0]
Output: [-1,0,3,4,5]

限制:


The number of nodes in the list is in the range [1, 5000].

-5000 <= Node.val <= 5000

二、思路

如果要遍历然后通过遍历每个链表节点,指针一个个改指向,比较麻烦,需要三个指针,节点数看起来不是很多,偷懒直接用STL进行排序然后再连在一起。前者方法后面补~


三、C++代码

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* insertionSortList(ListNode* head) {
        vector<ListNode*>vec;
        while(head){
            vec.push_back(head);
            head = head->next;
        }
        sort(vec.begin(), vec.end(), [&](ListNode* n1, ListNode* n2){
            return n1->val < n2->val;
        });
        for(int i = 0;i < vec.size(); i++){
            if(i == vec.size()-1){
                vec[i]->next = NULL;
            }else{
                vec[i]->next = vec[i+1];
            }
        }
        return vec.front();
    }
};


相关文章
|
6月前
|
存储 算法 数据挖掘
LeetCode 题目 88:双指针\直接\递归\插入排序\归并排序 实现合并两个有序数组
LeetCode 题目 88:双指针\直接\递归\插入排序\归并排序 实现合并两个有序数组
|
7月前
|
算法 测试技术 C#
[二分查找双指针]LeetCode881: 救生艇
[二分查找双指针]LeetCode881: 救生艇
|
7月前
|
Go 索引
[leetcode 链表]
[leetcode 链表]
|
算法 Go
【LeetCode 算法专题突破】链表(⭐)
【LeetCode 算法专题突破】链表(⭐)
47 0
【Leetcode——排序的循环链表】
一、力扣题之排序循环链表 题目如下:航班直达!! 二、解题思路 刚看到直到题我还是很迷的,没有写过类似的题目。 当我看到官方题解时,嘿嘿嘿三个字形容此时的心情。 首先需要知道,这道题是升序的,但是当我们找到最大节点时,最大节点的next是最小节点,这是循环链表的缘故
|
存储 算法 搜索推荐
LeetCode:215. 数组中的第K个最大元素——快速排序
题目描述:给定整数数组nums和整数** k**,请返回数组中第 k 个最大的元素。 请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。
|
存储 索引
LeetCode链表集锦
本篇文章是博主按照代码随想录的链表部分力扣题的一些见解,有一些自己的想法与代码随想录题解结合,能使这部分题理解的更加透彻。
78 0
LeetCode链表集锦
|
存储 算法 Java
【算法题解】 Day27 链表
今天的算法是 「链表」 相关,“算法题解系列文章旨在精选重点与易错的算法题,总结常见的算法思路与可能出现的错误,以实战习题的形式理解算法,使用算法。”
93 0
|
存储 算法 Java
【算法题解】 Day4 链表
今天的算法是 链表 相关,“算法题解系列文章旨在精选重点与易错的算法题,总结常见的算法思路与可能出现的错误,以实战习题的形式理解算法,使用算法。”
86 0