当前位置: 首页 > news >正文

【leetcode100-033】【链表】排序链表

【题干】

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

【思路】

  • 递归版归并法链表版~没什么特别好说的(非递归版归并也是可以哒,但是马上要考试了今天懒得写了!打个flag在这里也许哪天想起来会补写一下)
  • 首先是分割,这一步在链表里会麻烦一点,因为要找到链表的中点,得用快慢指针,快指针每次移动 2 步,慢指针每次移动 1步,当快指针到达链表末尾时,慢指针指向链表的中点。
  • 对拆出的两个子链表递归的进行拆分,直到达到递归出口(只有一个节点)
  • 逐层归并有序的子链表,done。

【题解】

class Solution {
public:ListNode* sortList(ListNode* head) {return sortList(head, nullptr);}ListNode* sortList(ListNode* head, ListNode* tail) {if (head == nullptr) {return head;}if (head->next == tail) {head->next = nullptr;return head;}ListNode* slow = head, *fast = head;while (fast != tail) {slow = slow->next;fast = fast->next;if (fast != tail) {fast = fast->next;}}ListNode* mid = slow;return merge(sortList(head, mid), sortList(mid, tail));}ListNode* merge(ListNode* head1, ListNode* head2) {ListNode* dummyHead = new ListNode(0);ListNode* temp = dummyHead, *temp1 = head1, *temp2 = head2;while (temp1 != nullptr && temp2 != nullptr) {if (temp1->val <= temp2->val) {temp->next = temp1;temp1 = temp1->next;} else {temp->next = temp2;temp2 = temp2->next;}temp = temp->next;}if (temp1 != nullptr) {temp->next = temp1;} else if (temp2 != nullptr) {temp->next = temp2;}return dummyHead->next;}
};

http://www.lryc.cn/news/276128.html

相关文章:

  • [Kubernetes]5. k8s集群StatefulSet详解,以及数据持久化(SC PV PVC)
  • 数据库系统-甘晴void学习笔记
  • Azure Machine Learning - 人脸识别任务概述与技术实战
  • 强化学习的数学原理学习笔记 - 蒙特卡洛方法(Monte Carlo)
  • DDIA 第十一章:流处理
  • webpack知识点总结(高级应用篇)
  • 均匀与准均匀 B样条算法
  • 2023年12 月电子学会Python等级考试试卷(一级)答案解析
  • 启发式算法解决TSP、0/1背包和电路板问题
  • 阿里云新用户的定义与权益
  • go语言多线程操作
  • GreatSQL社区2023全年技术文章总结
  • 【论文阅读笔记】Stable View Synthesis 和 Enhanced Stable View Synthesis
  • 网络报文分析程序的设计与实现(2024)
  • 贯穿设计模式-享元模式思考
  • 牛客刷题:BC45 小乐乐改数字(中等)
  • 设计模式学习2
  • Rust:如何判断位置结构的JSON串的成员的数据类型
  • Kafka(五)生产者
  • 【Leetcode】242.有效的字母异位词
  • 【数据库原理】(16)关系数据理论的函数依赖
  • 脆弱的SSL加密算法漏洞原理以及修复方法
  • SVN迁移至GitLab,并附带历史提交记录(二)
  • 如何创建容器搭建节点
  • 微众区块链观察节点的架构和原理 | 科普时间
  • React Admin 前端脚手架之ant-design-pro
  • 向爬虫而生---Redis 基石篇1 <拓展str>
  • 【野火i.MX6ULL开发板】利用microUSB线烧入Debian镜像
  • “我在大A炒自己”
  • js 颜色转换,RGB颜色转换为16进制,16进制颜色转为RGB格式