【每日一题】LeetCode 2848.与车相交的点(数组、哈希表、前缀和)

【每日一题】LeetCode 2848.与车相交的点(数组、哈希表、前缀和)

题目描述

给定一个二维整数数组 nums,其中 nums[i] = [starti, endi] 表示第 i 辆车的起点为 starti,终点为 endi。我们需要找出数轴上被车辆覆盖的整数点的总数。

思路分析

这个问题可以通过以下步骤解决:

  1. 初始化集合 :创建一个 HashSet 来存储数轴上被覆盖的整数点。
  2. 遍历车辆:对于数组中的每一辆车,遍历其起点到终点的每一个整数点。
  3. 添加点:将遍历到的每一个整数点添加到集合中。
  4. 计算结果:由于集合中的元素是唯一的,集合的大小即为被覆盖的整数点的总数。

输入示例

  • 输入:[[3,6],[1,5],[4,7]]

  • 输出:7

  • 解释:从 1 到 7 的所有点都至少与一辆车相交,因此答案为 7。

  • 输入:[[1,3],[5,8]]

  • 输出:7

  • 解释:1、2、3、5、6、7、8 共计 7 个点满足至少与一辆车相交,因此答案为 7。

代码实现

java 复制代码
class Solution {
    public int numberOfPoints(List<List<Integer>> nums) {
        // 初始化一个 HashSet 来存储被覆盖的整数点
        Set<Integer> set = new HashSet<>();
        // 获取车辆的数量
        int n = nums.size();
        // 遍历每一辆车
        for (int i = 0; i < n; i++) {
            // 获取当前车辆的起点和终点
            int start = nums.get(i).get(0);
            int end = nums.get(i).get(1);
            // 遍历当前车辆覆盖的每一个整数点
            for (int j = start; j <= end; j++) {
                // 将整数点添加到集合中
                set.add(j);
            }
        }
        // 返回集合的大小,即被覆盖的整数点的总数
        return set.size();
    }
}
相关推荐
CoovallyAIHub1 分钟前
基于SimCLR的自监督 YOLO:YOLOv5/8也能在低标注场景目标检测性能飙升
深度学习·算法·计算机视觉
q***d1735 分钟前
微服务与单体架构的成本对比
java·微服务·架构
冻感糕人~12 分钟前
Agent框架协议“三部曲”:MCP、A2A与AG-UI的协同演进
java·人工智能·学习·语言模型·大模型·agent·大模型学习
2501_9411118615 分钟前
C++模块化设计原则
开发语言·c++·算法
阿Y加油吧23 分钟前
java并发编程面试题精讲——day02
java·面试·c#
2501_9412375326 分钟前
基于C++的游戏引擎开发
开发语言·c++·算法
ArabySide27 分钟前
【Spring Boot】基于MyBatis的条件分页
java·spring boot·后端·mybatis
_OP_CHEN32 分钟前
算法基础篇:(十)贪心算法拓展之哈夫曼编码:从 “合并最优” 到数据压缩的传奇
c++·算法·贪心算法·蓝桥杯·哈夫曼编码·算法竞赛·acm/icpc
z***y86234 分钟前
后端服务限流配置,Nginx与Spring Cloud Gateway
java·服务器·nginx
l1t40 分钟前
利用DuckDB列表一句SQL输出乘法口诀表
数据库·sql·算法·duckdb