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.mzph.cn/news/1099105.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一键删除顽固文件(强制删除)

视频演示使用批处理脚本实现文件/文件夹拖放删除与权限管理 核心功能概述 批处理脚本&#xff08;echo off&#xff09;的作用与适用场景拖放文件/文件夹到脚本自动触发删除操作的设计原理权限提升&#xff08;takeown和icacls&#xff09;的必要性与安全考量 代码鉴赏&…

Conda install常见错误:解决Miniconda-Python3.11中的Solving Environment问题

Conda install常见错误&#xff1a;解决Miniconda-Python3.11中的Solving Environment问题 在数据科学和AI开发的日常中&#xff0c;你是否曾经历过这样的场景&#xff1a;敲下一行 conda install pytorch 后&#xff0c;终端卡在“Solving environment: /”长达数分钟&#xf…

Pyenv与Miniconda对比:哪个更适合管理Python3.11用于大模型训练

Pyenv与Miniconda对比&#xff1a;哪个更适合管理Python3.11用于大模型训练 在AI工程实践中&#xff0c;一个看似不起眼却影响深远的问题浮出水面&#xff1a;如何高效、可靠地管理Python环境&#xff1f; 尤其是当项目涉及大模型训练时&#xff0c;动辄数十GB的依赖库、复杂的…

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

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

清华源同步延迟?手动刷新Miniconda-Python3.11的索引缓存

清华源同步延迟&#xff1f;手动刷新Miniconda-Python3.11的索引缓存 在人工智能实验室的一次常规部署中&#xff0c;团队急着测试 PyTorch 2.3.0 的新特性&#xff0c;却发现 conda install pytorch 始终报错“Package not found”。奇怪的是&#xff0c;官方文档明明写着已发…

第十二章 遗传与发育

第十三章数量性状遗传第十四章群体遗传与进化

CCS使用系统学习:TI C2000多核工程管理技巧

深入TI C2000多核开发&#xff1a;用CCS打造高效、解耦的嵌入式系统你有没有遇到过这样的场景&#xff1f;在做一款数字电源或电机控制器时&#xff0c;控制环路跑得好好的&#xff0c;突然来了一个Modbus读请求&#xff0c;协议栈一跑&#xff0c;PWM周期直接抖动了几个微秒—…

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

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

Windows平台Keil5汉化包兼容性深度剖析

Keil5汉化包的“中文梦”&#xff1a;为何总在Windows上翻车&#xff1f;你有没有试过打开Keil5&#xff0c;面对满屏英文菜单时心里一紧&#xff1f;“Project”、“Target”、“Options for Target”……这些术语对老手来说早已烂熟于心&#xff0c;但对刚入门的嵌入式开发者…

清华源rsync同步脚本:自动更新Miniconda-Python3.11基础镜像

清华源rsync同步脚本&#xff1a;自动更新Miniconda-Python3.11基础镜像 在AI模型训练和数据科学项目中&#xff0c;一个常见的场景是&#xff1a;新成员加入团队后&#xff0c;花了一整天时间配置环境&#xff0c;却因为conda install时网络超时、包版本冲突或下载了损坏的安装…

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

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

世界模型 是什么 cuas

没错&#xff0c;“世界模型”正是解决刚才我们讨论的“AI 为什么无法操控电脑”这个问题的关键钥匙。简单来说&#xff0c;世界模型就是给 AI 安装一个“物理引擎”和“常识大脑”。刚才我说现在的 AI 像一个没有下过床的“超级大脑”&#xff0c;而世界模型就是那个能让它理解…

CSDN首页发布文章【分布鲁棒】数据驱动的多离散场景电热综合能源系统分布鲁棒优化算法研究(Matlab代码实现)46 / 1002020 年 9 月 22 号中国公布了碳中和目标,可见的

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

GitHub提交忽略文件:.gitignore配置Miniconda-Python3.11环境

GitHub提交忽略文件&#xff1a;.gitignore配置Miniconda-Python3.11环境 在数据科学和AI项目日益复杂的今天&#xff0c;一个常见的困扰是&#xff1a;为什么别人克隆了你的代码却“跑不起来”&#xff1f;更糟的是&#xff0c;你刚提交的代码仓库突然膨胀到几百MB——只因为不…

SSH反向隧道应用:从Miniconda-Python3.11服务器穿透回访本地

SSH反向隧道应用&#xff1a;从Miniconda-Python3.11服务器穿透回访本地 在AI开发日益依赖远程计算资源的今天&#xff0c;一个常见的困境浮出水面&#xff1a;训练任务跑在内网GPU服务器上&#xff0c;代码却写在本地笔记本里&#xff1b;可视化结果生成于防火墙后的实验室主机…

Keil5烧录STM32时的复位电路设计操作指南

Keil5烧录STM32&#xff1f;别再让复位电路拖后腿了&#xff01; 你有没有遇到过这种情况&#xff1a;Keil5编译通过、ST-Link也连上了&#xff0c;结果一点击“Download”&#xff0c;弹出个红字警告—— “No target connected” 或者 “Target failed to respond” &…

LVGL移植项目应用:嵌入式Linux下DRM驱动适配

如何在嵌入式Linux中用DRM“硬刚”LVGL&#xff1f;——绕过X11的高性能GUI实战你有没有遇到过这种情况&#xff1a;明明SoC性能不弱&#xff0c;UI动画却卡得像幻灯片&#xff1b;改了几行代码&#xff0c;界面刷新撕裂得像是老电视信号不良&#xff1b;系统一跑起来&#xff…

从零开始搭建深度学习环境:Miniconda+PyTorch+GPU实战教程

从零开始搭建深度学习环境&#xff1a;MinicondaPyTorchGPU实战教程 在如今的AI研发现场&#xff0c;一个常见的场景是&#xff1a;团队成员刚拿到服务器权限&#xff0c;兴致勃勃准备跑通第一个模型&#xff0c;结果卡在“ImportError: torchvision not found”&#xff1b;或…

SSH端口映射实战:将Miniconda-Python3.11的Jupyter服务暴露到本地

SSH端口映射实战&#xff1a;将Miniconda-Python3.11的Jupyter服务暴露到本地 在数据科学和AI开发中&#xff0c;一个常见的场景是&#xff1a;你手握一台配置强大的远程GPU服务器&#xff0c;上面跑着你的模型训练任务。你想用熟悉的 Jupyter Notebook 写代码、调参、看可视化…