2024年华为OD机试真题-手机App防沉迷系统-Java-OD统一考试(C卷)

news/2024/7/20 19:46:06 标签: 华为od, java, 算法

题目描述:

智能手机方便了我们生活的同时,也侵占了我们不少的时间。“手机App防沉迷系统”能够让我们每天合理的规划手机App使用时间,在正确的时间做正确的事。

它的大概原理是这样的:

1、在一天24小时内,可注册每个App的允许使用时段;

2、一个时段只能使用一个App,举例说明:不能同时在09:00-10:00注册App2和App3;

3、App有优先级,数值越高,优先级越高。注册使用时段时,如果高优先级的App时间和低优先级的时段有冲突,则系统会自动注销低优先级的时段;如果App的优先级相同,则后添加的App不能注册。

举例1:

(1)注册App3前:

(2)App3注册时段和App2有冲突:

(3)App3优先级高,系统接受App3的注册,自动注销App2的注册:

举例2:

(1)注册App4:

(2)App4和App2及App3都有冲突,优先级比App2高,但比App3低,这种场景下App4注册不上,最终的注册效果如下:

4、一个App可以在一天内注册多个时段。

请编程实现,根据输入数据注册App,并根据输入的时间点,返回该时间点可用的App名称,如果该时间点没有注册任何App,请返回字符串"NA"。

输入描述:

输入分3部分:第一行表示注册的App数N(N≤100);第二部分包括N行,每行表示一条App注册数据;最后一行输入一个时间点,程序即返回该时间点的可用App。

2

App1 1 09:00 10:00

App2 2 11:00 11:30

09:30

数据说明如下:

1、N行注册数据以空格分隔,四项数据依次表示:App名称、优先级、起始时间、结束时间

2、优先级1-5,数字值越大,优先级越高

3、时间格式HH:MM,小时和分钟都是两位,不足两位前面补0

4、起始时间需小于结束时间,否则注册不上

5、注册信息中的时间段包含起始时间点,不包含结束时间点

输出描述:

输出一个字符串,表示App名称,或NA表示空闲时间。

补充说明:

1、用例保证时间都介于00:00-24:00之间;

2、用例保证数据格式都是正确的,不用考虑数据输入行数不够、注册信息不完整、字符串非法、优先级超限、时间格式不正确的问题。

示例1

输入:

1
App1 1 09:00 10:00
09:30
输出:

App1
说明:

App1注册在9点到10点间,9点半可用的应用名是App1

示例2

输入:

2
App1 1 09:00 10:00
App2 2 09:10 09:30
09:20
输出:

App2
说明:

App1和App2的时段有冲突,App2的优先级比App1高,注册App2后,系统将App1的注册信息自动注销后,09:20时刻可用应用名是App2.

示例3

输入:

2
App1 1 09:00 10:00
App2 2 09:10 09:30
09:50
输出:

NA
说明:

App1被注销后,09:50时刻没有应用注册,因此输出NA。

代码报告

解题思路:这个题目很长,很符合华为的考试风格,一个简单的问题套上一个复杂的背景,就像阅读理解一样,如果你没提前看过题库,第一次遇到会很难的。考察对数组、字符串、编程基础、循环、统计的理解和运用。

java解法:

java">import java.util.Scanner;
import java.util.*;
 
 
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int N;
        N = in.nextInt();
        in.nextLine();
 
        List<App> list = new ArrayList<>(N);
 
        for (int i = 0; i < N; i++) {
            App app = new App();
            app.name = in.next();
            app.level = Integer.parseInt(in.next());
            app.start = timeToMin(in.next());
            app.end = timeToMin(in.next());
 
            if (app.start <= app.end) {
                list.add(app);
            }
        }
 
 
        List<Duration> dlist = new ArrayList<>();
       
 
        for (int i = 0; i < list.size(); i++ ) {
            if (i == 0) {
                App a = list.get(i);
 
                Duration d = new Duration();
                d.name = a.name;
                d.start = a.start;
                d.end = d.end;
                d.index = i;
                dlist.add(d);
                continue;
            }
 
            App current = list.get(i);
            Set<Integer> set = new HashSet<>();
            for (int j = current.start; j < current.end; j++) {
                for (int k = 0; k < dlist.size(); k++) {
                    Duration d = dlist.get(k);
 
                    if (j >= d.start && j < d.end) {
                        set.add(d.index);
                    }
                }
               
            }
 
            boolean isDown = false;
            for (int index : set) {
                if (list.get(index).level > current.level) {
                    isDown = true;
                }
            }
 
            if (isDown) {
 
            } else {
                for (int index : set) {
                    App a = list.get(index);
 
                    Duration d = new Duration();
 
                    d.name = a.name;
                    d.start = a.start;
                    d.end = a.end;
                    d.index = index;
 
                    dlist.remove(d);
                  
                Duration d = new Duration();
 
                d.name = current.name;
                d.start = current.start;
                d.end = current.end;
                d.index = i;
                dlist.add(d);
            }
        }
 
 
        String time = in.next();
 
        int min = timeToMin(time);
        Duration result = null;
        for (int k = 0; k < dlist.size(); k++) {
            Duration d = dlist.get(k);
 
            if (min >= d.start && min < d.end) {
                result = d;
            }
        }
 
 
        if (result == null) {
            System.out.print("NA");
        } else {
            System.out.print(result.name);
        }
 
    }
 
    static class App {
        String name;
        int level;
        int start;
        int end;
    }
 
    static public int timeToMin(String t) {
        String[] s = t.split(":");
        int hour = Integer.parseInt(s[0]);
        int min = Integer.parseInt(s[1]);
        return hour * 60 + min;
    }
 
    static public void setBitMap(int[] bitmap, int index, int start, int end) {
        for (int i = start; i <= end; i++) {
            bitmap[i] = index;
        }
    }
 
    static public void unsetBitMap(int[] bitmap, int start, int end) {
        for (int i = start; i <= end; i++) {
            bitmap[i] = -1;
        }
    }
 
    static class Duration {
        String name;
        int start;
        int end;
        int index;
 
        public boolean equals(Object o) {
            if (o == null) return false;
            Duration od = (Duration)o;
            return this.name.equals(od.name) && this.start == od.start &&
                   this.end == od.end && this.index == od.index;
        }
 
        public int hashCode() {
            return Objects.hash(new Object[] {this.name, this.start, this.end, this.index});
        }
    }
}


http://www.niftyadmin.cn/n/5324212.html

相关文章

电脑重置网络后连不上网了怎么办

一般电脑重置网络后都会自动重新下载好网络配置&#xff0c;但是不免会出现一些意外&#xff0c;接下来就我遇到的重置后无法联网的解决方案 做一个分享&#xff1a; 1、按下“winR”打开运行输入 services.msc 。 2、找到 WLAN AutoConfig 和 Wired AutoConfig 服务&#xff…

【书生·浦语】大模型实战营——第五课作业

教程文档&#xff1a;https://github.com/InternLM/tutorial/blob/vansin-patch-4/lmdeploy/lmdeploy.md#tritonserver-%E6%9C%8D%E5%8A%A1%E4%BD%9C%E4%B8%BA%E5%90%8E%E7%AB%AF 视频链接&#xff1a; 作业&#xff1a; 基础作业 使用如下命令创建conda环境 conda create…

多进程实现案例

多进程 多进程&#xff08;简单程序&#xff09; from multiprocessing import Process, Queueclass MyProcess(Process):def __init__(self, q, i):super().__init__()self.q qself.i idef run(self):print(子进程%s 开始put数据 % self.i)self.q.put(我是%s 通过Queue通信…

【Vue3】2-12 : 【案例】搜索关键词加筛选条件的综合

本书目录&#xff1a;点击进入 一、【案例】搜索关键词加筛选条件的综合 1.1、逻辑 1.2、效果 1.3、json数据 - 02-data.json 1.4、代码 一、【案例】搜索关键词加筛选条件的综合 1.1、逻辑 计算属性 - 绑定list&#xff0c;并过滤 input 双向绑定 - 当input改变时&…

依赖Kafka的Go单元测试例解

Kafka[1]是Apache基金会开源的一个分布式事件流处理平台&#xff0c;是Java阵营(最初为Scala)中的一款杀手级应用&#xff0c;其提供的高可靠性、高吞吐量和低延迟的数据传输能力&#xff0c;让其到目前为止依旧是现代企业级应用系统以及云原生应用系统中使用的重要中间件。 在…

书生·浦语 第三章:基于 InternLM 和 LangChain 搭建你的知识库

一、搭建环境 1.1 基础环境配置 在官方提供的教程中构建环境的命令如下 # 拷贝一个 pytorch 2.0.1 的环境 /root/share/install_conda_env_internlm_base.sh InternLM# 激活环境 conda activate InternLM# 安装一些依赖 python -m pip install --upgrade pip # 升级pip的版本…

【开源】基于JAVA+Vue+SpringBoot的超市账单管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块三、系统设计3.1 总体设计3.2 前端设计3.3 后端设计在这里插入图片描述 四、系统展示五、核心代码5.1 查询供应商5.2 查询商品5.3 新增超市账单5.4 编辑超市账单5.5 查询超市账单 六、免责说明 一、摘要 1.1 项目介绍 基于…

event bus

实现一个观察者类Observer&#xff0c;具有on、emit、remove方法。WeakMap用于生成键值对的集合&#xff0c;与Map不同的是&#xff0c;WeakMap只接受对象作为键名。 const events (() > {let _message new WeakMap()class event {constructor () {console.log(_message,…