力扣(leetcode)每日一题 2848 与车相交的点

2848. 与车相交的点 - 力扣(LeetCode)

题干

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

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

示例 1:

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

输出:7

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

示例 2:

输入:nums = [[1,3],[5,8]]

输出:7

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

提示:

1 <= nums.length <= 100

nums[i].length == 2

1 <= starti <= endi <= 100

解法1
java 复制代码
    public static int numberOfPoints(List<List<Integer>> nums) {
        TreeMap<Integer, Integer> map = new TreeMap<>();
        // 先进行排序  如果有线段1,10和1,5 在map中保证存放的是1,10这个数值更大的
        for (int i = 0; i < nums.size(); i++) {
            List<Integer> integers = nums.get(i);
            Integer key = integers.get(0);
            Integer valueOrigin = integers.get(1);
            Integer value = map.get(key);
            if (value == null || value < valueOrigin) {
                map.put(key, valueOrigin);
            }
        }
        int count = 0;
        // 再进行遍历
        Iterator<Map.Entry<Integer, Integer>> iterator = map.entrySet().iterator();
        int max = 0; // 这里的max是最大结算点
        while (iterator.hasNext()) {
            Map.Entry<Integer, Integer> entry = iterator.next();
            Integer key = entry.getKey();
            Integer value = entry.getValue();
            if (key > max) {  // 如果max为3 这里的线段为4,8 直接刷记录然后更新max为8 
                count += value - key + 1;
                max = value;
            }
            if (key <= max && value > max) { // 这里max为6    线段为4,8   需要更新的点是7到8 因为max已经结算过了,所以这里不需要加1
                count += value - max;
                max = value;
            }
        }
        return count;
    }

复杂度应该是n * logN + n 这里和数值无关

题解的复杂度是n+c c是元素的范围

下意识觉得元素的范围会很大是10的9次方级别。

解法2

讲一下题解的第二种做法

一个数组上,从左边到右边,如果有线段开始,count就加上1,如果有线段结束,count就减去1

这样count大于1 的位置上就肯定是有线段覆盖的。

java 复制代码
 public static int numberOfPoints(List<List<Integer>> nums) {
        int[] arr = new int[102];
        for (List<Integer> num : nums) {
            arr[num.get(0)]++; // 获取count,
            arr[num.get(1) + 1]--; // 归还count
        }
        int count = 0;
        int res = 0;
        for (int i : arr) {
            count += i;
            if (count > 0) {
                res++;
            }
        }
        return res;
    }
总结

一般的范围和数值不会给这么小,这纯摆着送分

相关推荐
卡尔特斯4 小时前
Android Kotlin 项目代理配置【详细步骤(可选)】
android·java·kotlin
白鲸开源4 小时前
Ubuntu 22 下 DolphinScheduler 3.x 伪集群部署实录
java·ubuntu·开源
ytadpole4 小时前
Java 25 新特性 更简洁、更高效、更现代
java·后端
纪莫4 小时前
A公司一面:类加载的过程是怎么样的? 双亲委派的优点和缺点? 产生fullGC的情况有哪些? spring的动态代理有哪些?区别是什么? 如何排查CPU使用率过高?
java·java面试⑧股
JavaGuide5 小时前
JDK 25(长期支持版) 发布,新特性解读!
java·后端
用户3721574261355 小时前
Java 轻松批量替换 Word 文档文字内容
java
白鲸开源5 小时前
教你数分钟内创建并运行一个 DolphinScheduler Workflow!
java
CoovallyAIHub6 小时前
中科大DSAI Lab团队多篇论文入选ICCV 2025,推动三维视觉与泛化感知技术突破
深度学习·算法·计算机视觉
Java中文社群6 小时前
有点意思!Java8后最有用新特性排行榜!
java·后端·面试
代码匠心6 小时前
从零开始学Flink:数据源
java·大数据·后端·flink