news 2026/6/10 16:23:38

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/30 22:01:45

打造终极OBS屏幕标注神器:5分钟学会实时绘图与直播标注

打造终极OBS屏幕标注神器&#xff1a;5分钟学会实时绘图与直播标注 【免费下载链接】obs-studio OBS Studio - 用于直播和屏幕录制的免费开源软件。 项目地址: https://gitcode.com/GitHub_Trending/ob/obs-studio 你是否在直播教学时苦于无法实时标注重点内容&#xff…

作者头像 李华
网站建设 2026/6/10 16:04:13

TradingAgents-CN智能交易系统实战部署:5分钟破解四大部署障碍

TradingAgents-CN智能交易系统实战部署&#xff1a;5分钟破解四大部署障碍 【免费下载链接】TradingAgents-CN 基于多智能体LLM的中文金融交易框架 - TradingAgents中文增强版 项目地址: https://gitcode.com/GitHub_Trending/tr/TradingAgents-CN 还在为复杂的AI交易系…

作者头像 李华
网站建设 2026/6/10 12:26:10

OptiScaler深度解析:5步让你的游戏帧率翻倍,画质更清晰

OptiScaler深度解析&#xff1a;5步让你的游戏帧率翻倍&#xff0c;画质更清晰 【免费下载链接】OptiScaler DLSS replacement for AMD/Intel/Nvidia cards with multiple upscalers (XeSS/FSR2/DLSS) 项目地址: https://gitcode.com/GitHub_Trending/op/OptiScaler 还在…

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

通义千问2.5-0.5B-Instruct快速入门:API接口调用指南

通义千问2.5-0.5B-Instruct快速入门&#xff1a;API接口调用指南 1. 引言 1.1 轻量级大模型的现实需求 随着边缘计算和终端智能设备的普及&#xff0c;对高效、低资源消耗的大语言模型&#xff08;LLM&#xff09;需求日益增长。传统大模型虽然性能强大&#xff0c;但往往需…

作者头像 李华
网站建设 2026/6/10 14:08:11

智能客服实战:用IndexTTS-2-LLM快速搭建语音问答系统

智能客服实战&#xff1a;用IndexTTS-2-LLM快速搭建语音问答系统 在智能客服系统不断演进的今天&#xff0c;用户对交互体验的要求已从“能回答”升级为“像人一样回答”。传统的文本回复模式虽然高效&#xff0c;但在情感传递、可访问性和场景适配方面存在明显短板。如何让客…

作者头像 李华
网站建设 2026/6/10 12:25:38

终极指南:零基础快速上手OpenCode终端AI编程

终极指南&#xff1a;零基础快速上手OpenCode终端AI编程 【免费下载链接】opencode 一个专为终端打造的开源AI编程助手&#xff0c;模型灵活可选&#xff0c;可远程驱动。 项目地址: https://gitcode.com/GitHub_Trending/openc/opencode 还在为每天重复的代码调试而烦恼…

作者头像 李华