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

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 类型)

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

感谢大家的三连支持!

http://www.jsqmd.com/news/168618/

相关文章:

  • Python安装第三方库:在Miniconda-Python3.11中使用pip与conda混合管理
  • 一张图讲清楚国自然逻辑结构
  • 一键删除顽固文件(强制删除)
  • Conda install常见错误:解决Miniconda-Python3.11中的Solving Environment问题
  • Pyenv与Miniconda对比:哪个更适合管理Python3.11用于大模型训练
  • 清华源同步延迟?手动刷新Miniconda-Python3.11的索引缓存
  • 第十二章 遗传与发育
  • 使用SMBus进行动态电压调节的技术路径:从零实现
  • CCS使用系统学习:TI C2000多核工程管理技巧
  • Jupyter内核配置错误?正确绑定Miniconda虚拟环境的方法
  • Windows平台Keil5汉化包兼容性深度剖析
  • 清华源rsync同步脚本:自动更新Miniconda-Python3.11基础镜像
  • Jupyter Lab集成PyTorch:基于Miniconda-Python3.11的一键启动方案
  • 世界模型 是什么 cuas
  • CSDN首页发布文章【分布鲁棒】数据驱动的多离散场景电热综合能源系统分布鲁棒优化算法研究(Matlab代码实现)46 / 1002020 年 9 月 22 号中国公布了碳中和目标,可见的
  • SSH反向隧道应用:从Miniconda-Python3.11服务器穿透回访本地
  • GitHub提交忽略文件:.gitignore配置Miniconda-Python3.11环境
  • Keil5烧录STM32时的复位电路设计操作指南
  • 从零开始搭建深度学习环境:Miniconda+PyTorch+GPU实战教程
  • LVGL移植项目应用:嵌入式Linux下DRM驱动适配
  • SSH端口映射实战:将Miniconda-Python3.11的Jupyter服务暴露到本地
  • 【USTC-Shaohua Kevin Zhou组-arXiv25】U-Bench:通过100种变体基准测试全面理解U-Net
  • 清华源HTTPS证书过期?临时禁用SSL验证以更新Miniconda-Python3.11
  • Keil5芯片包下载快速理解:适用于STM32
  • Jupyter Lab安装教程:比Notebook更强大的Miniconda-Python3.11 IDE
  • CSP-J 2025
  • Jupyter Notebook转脚本:使用Miniconda-Python3.11批量运行实验
  • 图解Keil5烧录STM32固件更新全过程(新手必看)
  • 大模型领域负载均衡技术
  • Markdown转PDF实战:在Miniconda-Python3.11中生成专业AI报告