不开心的小朋友 - 华为OD统一考试

2023-12-30 14:52

本文主要是介绍不开心的小朋友 - 华为OD统一考试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

OD统一考试

题解: Java / Python / C++

alt

题目描述

游乐场里增加了一批摇摇车,非常受小朋友欢迎,但是每辆摇摇车同时只能有一个小朋友使用如果没有空余的摇摇车,需要排队等候,或者直接离开,最后没有玩上的小朋友会非常不开心。请根据今天小朋友的来去情况,统计不开心的小朋友数量。

1、摇摇车数量为N,范围是: 1<=N<=10:

2、每个小朋友都对应一个编码,编码是不重复的数字,今天小朋友的来去情况可以使用编码表示为: 1 1 2 3 2 3。 (若小朋友离去之前有空闲的摇摇车则代表玩要后离开:不考虑小朋友多次玩的情况)。小朋友数量<=100

3、题目保证所有输入数据无异常目范围满足上述说明

输入描述

第一行: 摇摇车数量

第二行:小朋友来去情况

输出描述

返回不开心的小朋友数量

示例1

输入:
1
1 2 1 2输出:
0说明:
第一行,1个摇摇车
第二行,1号来 2号来(排队) 1号走 2号走(1号走后摇摇车已有空闲,所以玩后离开)

示例2

输入:
1
1 2 2 3 1 3输出:
1说明:
第一行,1个摇摇车
第二行,1号来 2号来 (排队) 2号走 (1号还没走,所以2号没玩3号来,1号走,3号走(1走后摇摇车有空闲,所以玩后离开)。只有2没玩

题解

模拟题

这个问题可以用队列来模拟小朋友玩摇摇车的过程。使用一个集合 playing 来记录当前正在玩摇摇车的小朋友,一个集合 unpappy 来记录因为没有玩到而不开心的小朋友,一个队列 waiting_queue 来记录排队的小朋友。

遍历输入的小朋友的来去情况,对每个小朋友进行如下操作:

  1. 如果小朋友在 playing 中,代表小朋友玩了一次后离开,此时需要检查排队队列 waiting_queue 是否有小朋友在排队,有的话让其中一个小朋友去玩,然后将其从排队队列中移除。
  2. 如果小朋友在 waiting_set 中,代表小朋友离开前排在摇摇车前排但是没有玩到,将其添加到 unpappy 中。
  3. 如果小朋友在 playingwaiting_set 中都不存在,说明小朋友是第一次来摇摇车。如果当前摇摇车有空位,直接让小朋友玩,并将其添加到 playing 中;否则,将小朋友添加到排队队列 waiting_queue 和排队集合 waiting_set 中。
  4. 最后输出 unpappy 集合的大小,即不开心的小朋友数量。

这个算法的时间复杂度是 O(N),其中 N 为小朋友的数量。

Java

import java.util.*;
/*** @author code5bug*/
public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int N = scanner.nextInt();Set<Integer> playing = new HashSet<>(), unpappy = new HashSet<>();Set<Integer> waitingSet = new HashSet<>();Deque<Integer> waitingQueue = new LinkedList<>();while (scanner.hasNext()) {int boy = scanner.nextInt();if (playing.contains(boy)) {  // 玩后离开playing.remove(boy);while (!waitingQueue.isEmpty()) {  // 检测是否有在排队,有排队则可让一个小朋友去玩int nextBoy = waitingQueue.poll();if (waitingSet.contains(nextBoy)) {  // 小朋友任然在排队playing.add(nextBoy);waitingSet.remove(nextBoy);break;}}} else if (waitingSet.contains(boy)) {  // 不想等直接离开(不开心)unpappy.add(boy);waitingSet.remove(boy);} else if (playing.size() < N) {  // 有空闲的可以玩playing.add(boy);} else {   // 没有空闲,进行排队waitingQueue.offer(boy);waitingSet.add(boy);}}System.out.println(unpappy.size());}
}

控制台模拟数据结束输入使用 Ctrl +D

Python

from collections import dequeN = int(input())
q = list(map(int, input().split()))# 正在玩的小朋友, 没玩到不开心的小朋友
playing, unpappy = set(), set()
# 排队队列,排队中的小朋友
waiting_set, waiting_queue = set(), deque()for boy in q:if boy in playing:  # 玩后离开playing.remove(boy)while waiting_queue:  # 检测是否有在排队, 有排队则可让一个小朋友去玩next_boy = waiting_queue.popleft()if next_boy in waiting_set:  # 小朋友任然在排队playing.add(next_boy)waiting_set.remove(next_boy)breakelif boy in waiting_set:  # 不想等直接离开(不开心)unpappy.add(boy)waiting_set.remove(boy)elif len(playing) < N:  # 有空闲的可以玩playing.add(boy)else:   # 没有空闲,进行排队waiting_queue.append(boy)waiting_set.add(boy)print(len(unpappy))

C++

#include <iostream>
#include <unordered_set>
#include <deque>using namespace std;int main() {int N;cin >> N;unordered_set<int> playing, unpappy, waitingSet;deque<int> waitingQueue;int boy;while (cin >> boy) {if (playing.count(boy)) {  // 玩后离开playing.erase(boy);while (!waitingQueue.empty()) {  // 检测是否有在排队,有排队则可让一个小朋友去玩int nextBoy = waitingQueue.front();waitingQueue.pop_front();if (waitingSet.count(nextBoy)) {  // 小朋友任然在排队playing.insert(nextBoy);waitingSet.erase(nextBoy);break;}}} else if (waitingSet.count(boy)) {  // 不想等直接离开(不开心)unpappy.insert(boy);waitingSet.erase(boy);} else if (playing.size() < N) {  // 有空闲的可以玩playing.insert(boy);} else {   // 没有空闲,进行排队waitingQueue.push_back(boy);waitingSet.insert(boy);}}cout << unpappy.size() << endl;return 0;
}

CodeBlocks 控制台结束输入使用 Ctrl + C

🙏整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

这篇关于不开心的小朋友 - 华为OD统一考试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/553204

相关文章

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

hdu 2093 考试排名(sscanf)

模拟题。 直接从教程里拉解析。 因为表格里的数据格式不统一。有时候有"()",有时候又没有。而它也不会给我们提示。 这种情况下,就只能它它们统一看作字符串来处理了。现在就请出我们的主角sscanf()! sscanf 语法: #include int sscanf( const char *buffer, const char *format, ... ); 函数sscanf()和

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

寻找身高相近的小朋友

题目描述: 小明今年升学到小学一年级,来到新班级后发现其他小朋友们身高参差不齐,然后就想基于各小朋友和自己的身高差对他们进行排序,请帮他实现排序。 输入描述: 第一行为正整数H和N,0<H<200,为小明的身高,0<N<50,为新班级其他小朋友个数。第二行为N个正整数H1-HN,分别是其他小朋友的身高,取值范围0<Hi<200(1<=i<=N),且N个正整数各不相同。 输出描述: 输出

828华为云征文|华为云Flexus X实例docker部署rancher并构建k8s集群

828华为云征文|华为云Flexus X实例docker部署rancher并构建k8s集群 华为云最近正在举办828 B2B企业节,Flexus X实例的促销力度非常大,特别适合那些对算力性能有高要求的小伙伴。如果你有自建MySQL、Redis、Nginx等服务的需求,一定不要错过这个机会。赶紧去看看吧! 什么是华为云Flexus X实例 华为云Flexus X实例云服务是新一代开箱即用、体

华为OD机试真题-学生方阵-2024年OD统一考试(E卷)

题目描述 学校组织活动,将学生排成一个矩形方阵。 请在矩形方阵中找到最大的位置相连的男生数量。这个相连位置在一个直线上,方向可以是水平的,垂直的,成对角线的或者呈反对角线的。 注:学生个数不会超过10000 输入描述 输入的第一行为矩阵的行数和列数, 接下来的 n行为矩阵元素,元素间用""分隔。 输出描述 输出一个整数,表示矩阵中最长的位

UML- 统一建模语言(Unified Modeling Language)创建项目的序列图及类图

陈科肇 ============= 1.主要模型 在UML系统开发中有三个主要的模型: 功能模型:从用户的角度展示系统的功能,包括用例图。 对象模型:采用对象、属性、操作、关联等概念展示系统的结构和基础,包括类图、对象图、包图。 动态模型:展现系统的内部行为。 包括序列图、活动图、状态图。 因为要创建个人空间项目并不是一个很大的项目,我这里只须关注两种图的创建就可以了,而在开始创建UML图

华为 HCIP-Datacom H12-821 题库 (13)

有需要题库的可以看主页置顶 1.可以携带外部路由的 tag 标签信息的是以下哪一类 LSA? A、4 类 LSA B、5 类 LSA  C、3 类 LSA  D、2 类 LSA 答案:B 解析: 暂无解析 2..两台路由器直连,并设定网络类型为 p2p 建立OSPF 邻居。那么两台路由器传输 OSPF 报文的目的 IP 地址是以下哪一项? A、使用组播地址 224.0.0.6 B

4G模块、WIFI模块、NBIOT模块通过AT指令连接华为云物联网服务器(MQTT协议)

MQTT协议概述 MQTT(Message Queuing Telemetry Transport)是一种轻量级的消息传输协议,它被设计用来提供一对多的消息分发和应用之间的通讯,尤其适用于远程位置的设备和高延迟或低带宽的网络。MQTT协议基于客户端-服务器架构,客户端可以订阅任意数量的主题,并可以发布消息到这些主题。服务器(通常称为MQTT Broker)则负责接受来自客户端的连接请求,并转发消