最少数量线段覆盖-华为OD

系列文章目录

文章目录


前言

本人最近再练习算法,所以会发布一些解题思路,希望大家多指教

一、题目描述

给定坐标轴上的一组线段,线段的起点和终点均为整数并且长度不小于1,请你从中找到最少数量的线段,这些线段可以覆盖住所有线段。

二、输入描述

第一行输入为所有线段的数量,不超过10000,后面每行表示一条线段,格式为"x,y",x和y分别表示起点和终点,取值范围是[-105,105]。

三、输出描述

最少线段数量,为正整数。

四、java代码

java 复制代码
public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int N = Integer.parseInt(sc.nextLine());
        List<int[]> list = new ArrayList<>();
        for (int i = 0; i < N; i++) {
            String[] split = sc.nextLine().split(" ");
            list.add(new int[]{Integer.parseInt(split[0]), Integer.parseInt(split[1])});
        }
        //按照线段的左侧下标进行正序排序,相同时,按照右侧下标正序排序
        list.sort(((o1, o2) -> {
            if (o1[0]==o2[0]) {
                return o1[1] - o2[1];
            } else {
                return o1[0] - o2[0];
            }
        }));
        //初始化线段数量,默认都无法完成覆盖
        int num = list.size();
        for (int i = 0; i < list.size(); i++) {
            int[] ints = list.get(i);
            if(i+1 <list.size()){
                //情况一:如果两个线段左侧下标相同,因为前面已经进行排序,所以后面的一定可以覆盖当前线段
                if(ints[0] == list.get(i+1)[0]){
                    num--;
                } else if(ints[1] >= list.get(i+1)[1]){
                    //情况二:如果右侧下标相同,则当前线段的一定可以覆盖下一个线段
                    num--;
                    //将下一个覆盖的线段的右侧下标进行延伸,继续向后比较
                    list.get(i+1)[1] = ints[1];
                }
            }
        }
        System.out.println(num);
    }

五、测试用例

输入:

6

15 20

3 6

8 12

1 7

11 15

18 20

相关推荐
今儿敲了吗7 分钟前
23| 画展
c++·笔记·学习·算法
Jasmine_llq25 分钟前
《AT_arc081_d [ARC081F] Flip and Rectangles》
算法·动态规划(dp)·贪心思想扩展 / 收缩边界·预处理转换网格状态·二维数组遍历实现逐点计算
野犬寒鸦25 分钟前
深入解析HashMap核心机制(底层数据结构及扩容机制详解剖析)
java·服务器·开发语言·数据库·后端·面试
##学无止境##2 小时前
从0到1吃透Java负载均衡:原理与算法大揭秘
java·开发语言·负载均衡
梵得儿SHI2 小时前
Spring Cloud 核心组件精讲:负载均衡深度对比 Spring Cloud LoadBalancer vs Ribbon(原理 + 策略配置 + 性能优化)
java·spring cloud·微服务·负载均衡·架构原理·对比单体与微服务架构·springcloud核心组件
Desirediscipline2 小时前
#define _CRT_SECURE_NO_WARNINGS 1
开发语言·数据结构·c++·算法·c#·github·visual studio
范纹杉想快点毕业2 小时前
C语言550例编程实例说明
算法
知识即是力量ol2 小时前
多线程并发篇(八股)
java·开发语言·八股·多线程并发
没有bug.的程序员2 小时前
Lombok 深度进阶:编译期增强内核、@Data 与 @Builder 逻辑博弈及工业级避坑实战指南
java·开发语言·python·builder·lombok·data·编译器增强
小O的算法实验室2 小时前
2026年SEVC SCI2区,面向无人机路径规划的领域专用算子进化算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进