利用归并算法对链表进行排序

/**

* 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* sortList(ListNode* head) {

if(head==nullptr||head->next==nullptr)return head;//对头指针进行判断

//利用快慢指针找到中间值mid

ListNode* slow=head;

ListNode* fast=head->next;

while(fast!=nullptr&&fast->next!=nullptr){

slow=slow->next;

fast=fast->next->next;

}

ListNode *mid=slow->next;

slow->next=nullptr;

//递归算法

ListNode* left=sortList(head);

ListNode* right=sortList(mid);

//将mid左右的链表进行合并

return merge(left,right);

}

private:

ListNode* merge(ListNode* l1,ListNode* l2){

//创建一个哑节点

ListNode dummy(0);//注意:此时dummy用的是栈上对象而不是堆上对象(即用ListNode而不是ListNode* dummy = new ListNode(0);)

/*原因如下:

栈上对象特点:

1.自动内存管理:函数结束时自动销毁,不需要手动释放

2.高效:栈分配比堆分配快得多

3.安全:不会内存泄漏

堆上对象特点:

1.需要手动管理内存:必须用 delete 释放,否则内存泄漏

2.较慢:堆分配比栈分配慢

3.容易出错:忘记释放会导致内存泄漏

*/

ListNode* tail=&dummy;//用tail接收

while(l1!=nullptr&&l2!=nullptr){

if(l1->val<l2->val){

tail->next=l1;

l1=l1->next;

}

else{

tail->next=l2;

l2=l2->next;

}

tail=tail->next;//尾指针后移

}

// 将剩余节点接到新链表尾部

tail->next=(l1!=nullptr)?l1:l2;//将剩余链表部分接上

return dummy.next;//返回头节点

}

/*

递归过程:

sortList(4→2→1→3)

├─ 找到中点:slow在2,mid=1→3

├─ left = sortList(4→2) → 返回 2→4

│ │

│ ├─ sortList(4→2)

│ │ ├─ 找到中点:slow在4,mid=2

│ │ ├─ left = sortList(4) → 4

│ │ ├─ right = sortList(2) → 2

│ │ └─ merge(4,2) → 2→4

│ │

├─ right = sortList(1→3) → 返回 1→3

│ │

│ ├─ sortList(1→3)

│ │ ├─ 找到中点:slow在1,mid=3

│ │ ├─ left = sortList(1) → 1

│ │ ├─ right = sortList(3) → 3

│ │ └─ merge(1,3) → 1→3

│ │

└─ merge(2→4, 1→3) → 1→2→3→4

*/

};

相关推荐
basketball61610 小时前
C++ 嵌套类完全指南:类中类的巧妙设计
开发语言·c++
吃好睡好便好10 小时前
在Matlab中绘制阶梯图
开发语言·人工智能·学习·算法·机器学习·matlab
Deep-w10 小时前
【MATLAB】基于 MATLAB 的离网光伏储能微电网容量优化仿真研究
开发语言·算法·matlab
kyle~10 小时前
ros_gz_bridge---底层通信的实现
c++·机器人·仿真·ros2
闵孚龙10 小时前
Qwen3.7-Max深度解析:智能体Agent、AI编程、MCP工作流、跨框架泛化与百炼API,一次讲透国产大模型新前沿
人工智能·算法·架构·ai编程
Jasmine_llq11 小时前
《B4261 [GESP202503 三级] 2025》
开发语言·c++·算法·条件判断算法·位运算恒等式推导·简单算术运算
小张成长计划..11 小时前
【C++】32:智能指针
c++
咩咦11 小时前
C++学习笔记19:运算符重载基础与赋值运算符重载
c++·学习笔记·类和对象·运算符重载·赋值运算符·operator
简单点好不好11 小时前
工作中的工程问题: 找圆?
算法
我爱cope11 小时前
【力扣hot100:76. 最小覆盖子串】
算法·leetcode·职场和发展