news 2026/5/1 1:15:58

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/5/1 9:08:49

CANoe环境下UDS诊断会话控制:完整示例

在CANoe中玩转UDS会话控制&#xff1a;从协议解析到CAPL实战 你有没有遇到过这样的场景&#xff1f; 刚接上诊断仪&#xff0c;准备读取ECU故障码&#xff0c;结果命令发出去没反应——查了半天才发现&#xff0c;根本还没进入正确的 诊断会话模式 。 这背后&#xff0c;正…

作者头像 李华
网站建设 2026/5/1 10:50:09

范式跃迁:2025,一位技术人在大模型浪潮中的破局与深耕

当传统机器学习的思维宫殿开始震动&#xff0c;从DeepSeek席卷而来的大模型浪潮&#xff0c;不仅改变了AI界的技术版图&#xff0c;也重塑着每一位技术人的知识边界。 本文所引用的所有文章&#xff0c;均为本人 2025 年内的原创文章。由于篇幅所限&#xff0c;仅引用少量文章作…

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

机器学习--K-means聚类DBSCANTF-IDF

一、K-means聚类 1、基本概念 1&#xff09;聚成多少个簇&#xff1a;需要知道K的值 2&#xff09;距离的度量&#xff1a;一般采用欧式距离 3&#xff09;质心&#xff1a;各向量的均值 4&#xff09;优化目标&#xff1a; 2、常见的距离 3、步骤 4、聚类效果评价方式 1…

作者头像 李华
网站建设 2026/5/1 10:59:38

Jupyter Lab集成PyTorch:基于Miniconda-Python3.11的一键启动方案

Jupyter Lab集成PyTorch&#xff1a;基于Miniconda-Python3.11的一键启动方案 在人工智能项目开发中&#xff0c;最令人头疼的往往不是模型设计本身&#xff0c;而是“环境配置”这个前置门槛。你是否经历过这样的场景&#xff1a;一篇论文复现代码下载下来后&#xff0c;跑不通…

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

大厂数据结构面试题合集

一、数组与矩阵 1、把数组中的 0 移到末尾 283. Move Zeroes (Easy) Leetcode / 力扣 For example, given nums = [0, 1, 0, 3, 12], after calling your function, nums should be [1, 3, 12, 0, 0].public void moveZeroes(int[] nums) {int idx = 0;for (int num : nums…

作者头像 李华
网站建设 2026/5/1 8:34:33

清华源HTTPS证书过期?临时禁用SSL验证以更新Miniconda-Python3.11

清华源HTTPS证书过期&#xff1f;临时禁用SSL验证以更新Miniconda-Python3.11 在人工智能和数据科学项目中&#xff0c;环境配置往往是第一步&#xff0c;也是最容易“卡住”的一步。你是否曾遇到这样的场景&#xff1a;刚搭好开发机&#xff0c;兴致勃勃地准备安装 Miniconda …

作者头像 李华