news 2026/6/10 21:55:56

12.30 - 合并区间 C++中class和C语言中struct的区别

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
12.30 - 合并区间 C++中class和C语言中struct的区别

目录

1.合并区间

a.核心思想

b.思路

c.步骤

2.C++中class和C语言中struct的区别


1.合并区间

56. 合并区间 - 力扣(LeetCode)https://leetcode.cn/problems/merge-intervals/

class Solution { public: vector<vector<int>> merge(vector<vector<int>>& intervals) { // 如果区间数组为空,直接返回空数组 if (intervals.empty()) return {}; // 按照区间的起始点进行排序 sort(intervals.begin(), intervals.end(), [](const vector<int>& a, const vector<int>& b) { return a[0] < b[0]; }); vector<vector<int>> res; res.push_back(intervals[0]); for (int i = 1; i < intervals.size(); ++i) { // 如果当前区间的起始点小于等于结果数组中最后一个区间的结束点,进行合并 if (intervals[i][0] <= res.back()[1]) { res.back()[1] = max(res.back()[1], intervals[i][1]); } // 否则,将当前区间加入结果数组 else { res.push_back(intervals[i]); } } return res; } };

a.核心思想

利用排序和合并的思路,先将所有区间按照起始点进行排序,然后依次遍历这些区间,将重叠的区间合并。

b.思路

① 对给定的区间数组按照每个区间的起始点进行升序排序。

② 初始化一个结果数组,将第一个区间放入结果数组。

③ 从第二个区间开始遍历,比较当前区间的起始点和结果数组中最后一个区间的结束点:

  • 如果当前区间的起始点小于等于结果数组中最后一个区间的结束点,说明有重叠,更新结果数组中最后一个区间的结束点为两者结束点的较大值。

  • 否则,将当前区间直接加入结果数组。

c.步骤

① 使用sort函数对区间数组进行排序。

② 创建结果数组res,并将排序后的第一个区间加入res

③ 遍历排序后的区间数组,从第二个区间开始,按照上述思路进行合并操作。

④ 返回结果数组res

2.C++中class和C语言中struct的区别

class

struct

默认访问权限

成员默认private

成员默认public

默认继承方式

默认private

默认public

成员功能

支持成员函数、构造函数、析构函数等

仅含数据成员,无函数

面向对象特性

支持封装、继承、多态

在 C++ 中可部分支持(需显式声明),C 语言中完全不支持

用途倾向

用于封装数据+行为的对象模型

常用于数据聚合(如 POD 类型)

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

感谢大家的三连支持!

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

STC89C52蜂鸣器报警电路设计:操作指南

用STC89C52玩转蜂鸣器&#xff1a;从电路到代码的实战全解析 你有没有遇到过这样的情况&#xff1f; 系统明明已经检测到异常&#xff0c;可就是没人注意到——直到加了个“嘀嘀”响的蜂鸣器&#xff0c;问题立刻被发现。声音提示看似简单&#xff0c;却是嵌入式系统中最直接、…

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

Jupyter内核配置错误?正确绑定Miniconda虚拟环境的方法

Jupyter内核配置错误&#xff1f;正确绑定Miniconda虚拟环境的方法 在数据科学和AI开发的日常工作中&#xff0c;你是否遇到过这样的场景&#xff1a;在一个精心配置的Miniconda环境中安装了所有依赖库&#xff0c;打开Jupyter Notebook后却发现无法导入刚装的包&#xff1f;或…

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

使用SMBus进行动态电压调节的技术路径:从零实现

从零构建基于SMBus的动态电压调节系统&#xff1a;实战全解析你有没有遇到过这样的场景&#xff1f;FPGA在高负载下突然复位&#xff0c;排查良久才发现是供电电压跳变太猛&#xff1b;或者服务器待机功耗居高不下&#xff0c;只因电源模块还在输出满额电压——明明负载已经休眠…

作者头像 李华
网站建设 2026/6/9 22:16:06

Jupyter魔法命令大全:提升Miniconda-Python3.11交互式编程效率

Jupyter魔法命令与Miniconda-Python3.11的高效协同开发实践 在当今AI和数据科学项目日益复杂的背景下&#xff0c;一个稳定、可复现且高效的交互式开发环境已成为工程师和科研人员的核心生产力工具。你是否曾遇到过这样的场景&#xff1a;刚写完一段模型训练代码&#xff0c;却…

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

2026年,我该信哪个AI证书?

说实话&#xff0c;最近跟几个正在琢磨考AI证书的朋友聊天&#xff0c;发现大家纠结的点出奇地一致。一个在互联网公司做运营的学妹跟我吐槽&#xff1a;“我看好多岗位都说‘有AI相关认证优先’&#xff0c;可我去研究了一圈&#xff0c;懵了。那些国际大厂的证&#xff0c;一…

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

PyTorch安装教程GPU版:Miniconda-Python3.11镜像一键部署深度学习环境

PyTorch GPU环境一键部署&#xff1a;基于Miniconda-Python3.11的深度学习实战配置 在AI模型训练日益依赖GPU算力的今天&#xff0c;一个稳定、高效且可复现的开发环境&#xff0c;往往比算法本身更早成为项目成败的关键。你是否曾经历过这样的场景&#xff1a;花费整整两天时间…

作者头像 李华