华为OD机考-观看文艺汇演问题-区间问题(JAVA 2025B卷)


java 复制代码
import java.util.*;
/**
 * @version Ver 1.0
 * @date 2025/6/20
 * @description 观看文艺汇演
 */
public class WatchMovie {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int num = Integer.parseInt(sc.nextLine());
        List<Movie> movies = new ArrayList<>(num);
        for (int i = 0; i < num; i++) {
            int[] array = Arrays.stream(sc.nextLine().split("\\s+")).mapToInt(Integer::parseInt).toArray();
            movies.add(new Movie(array[0],array[1]));
        }
        // 按照结束时间 升序排序
        movies.sort((m1,m2)->{
            return m1.getEndTime() - m2.getEndTime();
        });
        solve(movies);
    }

    private static void solve(List<Movie> movies) {
        //720 120
        //840 120
        //0 60
        //90 60
        int count = 0;
        int tempTime = 0;//记录上一场演出的结束时间+去下一场演出花费的时间
        for (int i = 0; i < movies.size(); i++) {
            Movie current = movies.get(i);
            if(current.getStartTime() >= tempTime){//下一场演出开始时间>=tempTime,才能看演出
                tempTime = current.getEndTime()+15;
                count++;
            }
        }
        System.out.println(count);
    }
}

class Movie{
    private Integer startTime;
    private Integer endTime;

    public Movie() {
    }

    public Integer getStartTime() {
        return startTime;
    }

    public void setStartTime(Integer startTime) {
        this.startTime = startTime;
    }

    public Integer getEndTime() {
        return endTime;
    }

    public void setEndTime(Integer endTime) {
        this.endTime = endTime;
    }

    public Movie(Integer startTime, Integer dual) {
        this.startTime = startTime;
        this.endTime = startTime + dual;
    }
}
相关推荐
小王不爱笑1324 分钟前
SpringBoot 自动装配深度解析:从底层原理到自定义 starter 实战(含源码断点调试)
java·spring boot·mybatis
森林里的程序猿猿7 分钟前
Spring Aop底层源码实现(一)
java·后端·spring
weixin_4563216437 分钟前
Java架构设计:Redis持久化方案整合实战
java·开发语言·redis
攒了一袋星辰1 小时前
SequenceGenerator高并发有序顺序号生成中间件 - 架构设计文档
java·后端·spring·中间件·架构·kafka·maven
lzp07911 小时前
SpringBoot3.3.0集成Knife4j4.5.0实战
java
Memory_荒年1 小时前
TiDB:当 MySQL 遇上分布式,生了个“超级混血儿”
java·数据库·后端
asom221 小时前
DDD(领域驱动设计) 核心概念详解
java·开发语言·数据库·spring boot
Aawy1202 小时前
Python生成器(Generator)与Yield关键字:惰性求值之美
jvm·数据库·python
大傻^2 小时前
LangChain4j Spring Boot Starter:自动配置与声明式 Bean 管理
java·人工智能·spring boot·spring·langchain4j
沐硕2 小时前
《基于改进协同过滤与多目标优化的健康饮食推荐系统设计与实现》
java·python·算法·fastapi·多目标优化·饮食推荐·改进协同过滤