C语言 | Leetcode C语言题解之第147题对链表进行插入排序

题目:

题解:

cpp 复制代码
struct ListNode *insertionSortList(struct ListNode *head) {
    if (head == NULL) {
        return head;
    }
    struct ListNode *dummyHead = malloc(sizeof(struct ListNode));
    dummyHead->val = 0;
    dummyHead->next = head;
    struct ListNode *lastSorted = head;
    struct ListNode *curr = head->next;
    while (curr != NULL) {
        if (lastSorted->val <= curr->val) {
            lastSorted = lastSorted->next;
        } else {
            struct 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;
}
相关推荐
2301_795167204 小时前
玩转Rust高级应用 如何避免对空指针做“解引用”操作,在C/C++ 里面就是未定义行为
c语言·c++·rust
ben9518chen9 小时前
嵌入式Linux C语言程序设计九
linux·c语言
下午见。10 小时前
C语言结构体入门:定义、访问与传参全解析
c语言·笔记·学习
cs麦子10 小时前
C语言--函数(function)
c语言·开发语言
极智-99610 小时前
C语言编译器?【图文详解】Visual Studio安装配置编译运行C语言?C语言编译器下载安装?
c语言·visual studio·c语言编译器·c代码运行·visual studio下载·c编程·c语言下载
是苏浙10 小时前
零基础入门C语言之C语言实现数据结构之顺序表
c语言·开发语言·数据结构
代码雕刻家10 小时前
C语言中关于类型转换不匹配的解决方案
c语言·开发语言·算法
许长安13 小时前
c/c++ static关键字详解
c语言·c++·经验分享·笔记
逐步前行13 小时前
C数据结构--排序算法
c语言·数据结构·排序算法
小安同学iter14 小时前
SQL50+Hot100系列(11.7)
java·算法·leetcode·hot100·sql50