【每日一题】06 排序链表

问题描述

给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表 。

求解

c 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
struct ListNode* sortList(struct ListNode* head) {
        struct ListNode * p = head;
        if(p == NULL){
            return head;
        }
        struct ListNode * q = head->next;
        int t;
        while(p->next != NULL){
            while(q !=NULL){
                
                //printf("before: p: %d, q: %d\n", p->val, q->val);
                if(p->val > q->val){
                    t = p->val;
                    p->val = q->val;
                    q->val = t;
                }
                //printf("after: p: %d, q: %d\n", p->val, q->val);
                q = q->next;
                
            

            }
            p = p->next;
            //printf("p : %d\n", p->val);
            q = p->next;
            //printf("q : %d\n", q->val);
        }

        
        return head;
}

该方法时间复杂度O(n^2)过高

后续补上使用快速排序方法提升时间复杂度

相关推荐
海清河晏1117 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
liulilittle7 小时前
固定数组时间轮的槽过载优化:桶链表与批次执行
网络·数据结构·链表
Irissgwe8 小时前
数据结构-栈和队列
数据结构·c++·c·栈和队列
两片空白8 小时前
数据容器集合set/frozenset
数据结构
代码中介商9 小时前
跳表:高效查找的链表黑科技
数据结构
SHARK_pssm11 小时前
【数据结构——树与堆】
c语言·数据结构·经验分享·笔记
RH23121112 小时前
2026.6.10 数据结构 二叉树
数据结构
Tisfy12 小时前
LeetCode 2130.链表最大孪生和:转数组 / 快慢指针+链表翻转(O(1))
算法·leetcode·链表·题解
CHHH_HHH13 小时前
【C++】哈希表原理与实战:从冲突解决到性能优化
开发语言·数据结构·c++·学习·算法·哈希算法·散列表
Irissgwe13 小时前
数据结构-排序
数据结构·算法·排序算法