news 2026/5/1 8:39:40

1.17 - 排序链表 虚函数指针是什么时候初始化的

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
1.17 - 排序链表 虚函数指针是什么时候初始化的

目录

1.排序链表

a.核心思想

b.思路

c.步骤

2.虚函数指针是什么时候初始化的


1.排序链表

148. 排序链表 - 力扣(LeetCode)https://leetcode.cn/problems/sort-list/

/** * 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; // 找到中点 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); // 合并两个有序链表 return merge(left, right); } ListNode* merge(ListNode* l1, ListNode* l2) { ListNode dummy(0); ListNode* tail = &dummy; 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; } };

a.核心思想

利用归并排序的思想对链表进行排序,归并排序适合链表的排序,因为其合并过程只需要改变节点的指针指向,而不需要像数组那样进行大量的数据移动。

b.思路

① 分解:找到链表的中点,将链表分成两个子链表。

递归排序:对两个子链表分别进行递归排序。

③ 合并:将两个排好序的子链表合并成一个有序的链表。

c.步骤

① 找到中点:使用快慢指针法,快指针每次走两步,慢指针每次走一步,当快指针到达链表末尾时,慢指针指向的就是中点。

递归终止条件:当链表为空或只有一个节点时,直接返回该链表。

③ 合并链表创建一个虚拟头节点,然后比较两个子链表的节点值,将较小的节点连接到新链表上,直到其中一个子链表为空,然后将另一个子链表直接连接到新链表末尾。

2.虚函数指针是什么时候初始化的

① 基类构造阶段:调用基类构造函数时,vptr指向基类的虚函数表(vtable)。

② 派生类构造阶段:调用派生类构造函数时,vptr被更新为指向派生类的vtable。

③ 析构阶段:析构时逆向更新,先析构派生类(vptr指向派生类vtable),再析构基类(vptr指向基类vtable)。

希望这些内容对大家有所帮助!

感谢大家的三连支持!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 8:38:41

Mindustry终极安装指南:5步快速上手开源自动化塔防游戏

Mindustry终极安装指南&#xff1a;5步快速上手开源自动化塔防游戏 【免费下载链接】Mindustry The automation tower defense RTS 项目地址: https://gitcode.com/GitHub_Trending/min/Mindustry Mindustry是一款独特的开源自动化塔防实时战略游戏&#xff0c;它将塔防…

作者头像 李华
网站建设 2026/4/28 10:12:31

科哥镜像实测:阿里中文ASR识别准确率真惊艳

科哥镜像实测&#xff1a;阿里中文ASR识别准确率真惊艳 1. 引言 在语音交互日益普及的今天&#xff0c;高精度、低延迟的中文语音识别&#xff08;ASR&#xff09;系统已成为智能应用的核心组件。然而&#xff0c;许多开源方案在真实场景中面临识别准确率不足、专业术语识别偏…

作者头像 李华
网站建设 2026/5/1 7:17:30

FST ITN-ZH技术揭秘:中文文本标准化模型

FST ITN-ZH技术揭秘&#xff1a;中文文本标准化模型 1. 简介与背景 在自然语言处理&#xff08;NLP&#xff09;的实际应用中&#xff0c;语音识别系统输出的文本通常包含大量非标准表达形式。例如&#xff0c;“二零零八年八月八日”或“早上八点半”这类口语化、文字化的表…

作者头像 李华
网站建设 2026/5/1 6:56:28

AI智能二维码工坊性能优势:响应速度对比测试报告

AI智能二维码工坊性能优势&#xff1a;响应速度对比测试报告 1. 引言 1.1 选型背景 在当前数字化办公与移动互联网高度普及的背景下&#xff0c;二维码作为信息传递的重要载体&#xff0c;广泛应用于支付、身份认证、广告推广、设备连接等多个场景。随着使用频率的提升&…

作者头像 李华
网站建设 2026/4/18 7:04:38

KiCad原理图审查流程规范:团队协作中的关键步骤

如何让 KiCad 团队协作不再“翻车”&#xff1f;一套实用的原理图审查实战指南你有没有遇到过这样的场景&#xff1a;PCB 打样回来&#xff0c;发现某个芯片的封装引脚反了&#xff1b;电源模块明明仿真没问题&#xff0c;实测却反复重启&#xff1b;多人协作时&#xff0c;同事…

作者头像 李华
网站建设 2026/4/22 21:28:41

音乐播放器终极进化:5步打造你的专属听觉空间

音乐播放器终极进化&#xff1a;5步打造你的专属听觉空间 【免费下载链接】foobox-cn DUI 配置 for foobar2000 项目地址: https://gitcode.com/GitHub_Trending/fo/foobox-cn 还在用千篇一律的音乐播放器界面吗&#xff1f;foobox-cn将彻底改变你对音乐播放的认知&…

作者头像 李华