2026华为OD机考真题附答案-准备生日礼物

题目描述:

小明在一个充满人文关怀的公司上班,公司每个月都要为该月生日的同事送一份生日小礼物,该事项由小明负责,请帮助小明统计

某一月份应该准备多少礼物,重复录入的员工生日以最后一次录入结果为准,请不要重复统计,避免浪费。

输入描述

参数1,要发放礼物的月份,取值1到12。

参数2,员工列表。

参数3,员工生日日期列表,该列表和员工列表中的数据对应存在一一对应关系,长度一致。

输出描述

该月份要准备的礼品个数。

补充说明

1.小明公司的员工人数不超过100人。

2.员工姓名是字母和数字的组合,姓名长度大于0,小于16字节。

3.日期录入格式统一采用Year/Month/Day,Year 长度为4,Month和Day长度为1到2,系统保证录入

日期为合法日期。

4.不考虑同名多位员工的情况,名字一致即可认为是同一员工(在生产系统会通过工号区分,本系统简化处理)。

示例1

输入

5

Alice Bob Charlie David Eve Frank Grace Helen

1985/5/10 1990/10/11 1995/10/11 2000/11/10 2005/05/01 2010/10/13 2015/10/14 2020/5/2

输出

3

说明

在5 月份出生的员工有 3人,因此返回为 3。

示例2

输入

10

Alice Bob Charlie David Eve Frank Grace Helen

1985/05/10 1990/10/11 1995/10/11 2000/11/10 2005/10/13 2010/10/13 2015/10/14 2020/10/15

输出

6

说明

10 月份出生的员工有 6人,因此返回 6。

package org.example;

import java.util.HashMap;

import java.util.Map;

public class 准备生日礼物 {

复制代码
public static int countPeople(int month, String employees, String birthdays) {
    String[] birthdayArray = birthdays.split(" ");
    String[] employeeArray = employees.split(" ");
    // HashMap去重 key= 姓名,value = 生日 重复覆盖
    Map<String, String> empMap = new HashMap<>();
    for (int i = 0; i < employees.length(); i++) {
        empMap.put(employeeArray[i],birthdayArray[i]);
    }
    int res = 0;
    for (String s : empMap.values()) {
        String[] mon = s.split("/");
        if (Integer.parseInt(mon[1]) == month) {
            res++;
        }
    }
    return res;
}

}

相关推荐
超梦dasgg1 小时前
Java 生产环境 RocketMQ 架构与部署指南
java·rocketmq·java-rocketmq
Trouvaille ~1 小时前
【Redis篇】Hash 哈希:字段级操作与对象存储的最佳实践
数据库·redis·后端·算法·缓存·哈希算法·键值对
cheems95271 小时前
JWT令牌是如何实现登录认证的
java
happyprince1 小时前
10-Hugging Face Transformers 量化系统深度分析
java·前端·数据库
budingxiaomoli1 小时前
利用Hutool完成验证码案例
java
山人在山上1 小时前
docker离线安装
java·docker·eureka
Rust研习社1 小时前
Nightly 前瞻:cargo-script 让 Rust 也能写脚本
后端·rust·编程语言
AskHarries1 小时前
Chrome 插件有没有机会
后端
浩风祭月1 小时前
一次诡异的 MySQL 死锁,靠 AI 分析日志十分钟定位根因
后端·ai编程