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

2848、与车相交的点

2848、[简单] 与车相交的点

1、题目描述

给你一个下标从 0 开始的二维整数数组 nums 表示汽车停放在数轴上的坐标。对于任意下标 inums[i] = [starti, endi] ,其中 starti 是第 i 辆车的起点,endi 是第 i 辆车的终点。

返回数轴上被车 任意部分 覆盖的整数点的数目。

2、解题思路

排序和合并区间

  • 首先对汽车坐标区间进行排序,使得区间按照起点从小到大排列。
  • 然后,通过遍历排序后的区间来合并重叠的区间。
  • 合并的过程是:如果当前区间的起点在已合并区间的终点之后,说明没有重叠,直接添加新的区间;否则,更新已合并区间的终点。

计算覆盖点数

  • 合并完所有区间后,计算每个合并后的区间所覆盖的整数点数,并累加到结果中。

3、代码实现

class Solution {
public:
    int numberOfPoints(vector<vector<int>>& nums) {
        if (nums.size() == 0) {
            return 0; // 如果没有汽车,返回0
        }
        
        vector<vector<int>> ans; // 用于存储合并后的区间
        sort(nums.begin(), nums.end()); // 按区间起点进行排序
        ans.push_back(nums[0]); // 将第一个区间加入结果集
        
        for (int i = 1; i < nums.size(); i++) {
            if (ans.back()[1] < nums[i][0]) {
                // 当前区间与最后一个合并区间不重叠,添加新的区间
                ans.push_back(nums[i]);
            } else {
                // 合并区间,更新终点
                ans.back()[1] = max(ans.back()[1], nums[i][1]);
            }
        }
        
        int ret = 0; // 结果变量
        for (const auto& v : ans) {
            // 计算每个合并后区间的覆盖点数
            ret += v[1] - v[0] + 1;
        }
        
        return ret; // 返回被覆盖的整数点数
    }
};

4、复杂度分析

  • 时间复杂度O(n log n),主要是排序的时间复杂度,其中 n 是汽车的数量。
  • 空间复杂度O(n),用于存储合并后的区间。

http://www.kler.cn/a/456304.html

相关文章:

  • VSCode outline显示异常的解决方法——清除VSCode的配置和用户文件
  • 构建全志 T113 Tina SDK
  • 【zookeeper核心源码解析】第四课:客户端与服务端读写的io核心流程
  • Elasticsearch:使用 Ollama 和 Go 开发 RAG 应用程序
  • curl+openssl 踩坑笔记
  • 通过百度api处理交通数据
  • Kafka 数据传输的事务类型
  • SLES网络
  • 【机器学习(九)】分类和回归任务-多层感知机(Multilayer Perceptron,MLP)算法-Sentosa_DSML社区版 (1)111
  • 机器学习随机森林回归时间序列预模型中时间滑动窗口作用以及参数设置
  • 基于openEuler22.09部署OpenStack Yoga云平台(一)
  • 《机器视觉:开启智能新时代》
  • MySQL学习之表查询操作
  • Express.js 有哪些常用的中间件?
  • 【Flutter_Web】Flutter编译Web第三篇(网络请求篇):dio如何改造方法,变成web之后数据如何处理
  • 【Java】线程相关面试题 (基础)
  • 工业安全监测审计系统(源码+文档+部署+讲解)
  • 【我的 PWN 学习手札】IO_FILE 之 stdout任意地址读
  • 普通的树形数据primevue的treetable组件的treetable[ ]
  • android系统查找应用包名以及主activity:
  • WPF 绘制过顶点的圆滑曲线(样条,贝塞尔)
  • 创建用于预测序列的人工智能模型,用Keras Tuner探索模型的超参数。
  • PDF书籍《手写调用链监控APM系统-Java版》第8章 插件与链路的结合:Gson插件实现
  • Arcgis中python工具箱制造要点及统计要素图层字段信息工具分享
  • 【每日学点鸿蒙知识】组件封装通用方法、callback和await性能对比、Web组件下拉刷新、hsp包报错、WebView圆角
  • 使用 Three.js 创建一个 3D 人形机器人仿真系统