【Py/Java/C++三种语言OD2023C卷真题】20天拿下华为OD笔试【DP】2023C-分班【欧弟算法】全网注释最详细分类最全的华为OD真题题解
文章目录
- 题目描述与示例
- 题目描述
- 输入描述
- 输出描述
- 示例一
- 输入
- 输出
- 示例二
- 输入
- 输出
- 解题思路
- 代码
- Python
- Java
- C++
- 时空复杂度
- 华为OD算法/大厂面试高频题算法练习冲刺训练
题目描述与示例
题目描述
幼儿园两个班的小朋友在排队时混在了一起,每位小朋友都知道自己是否与前面一位小朋友是否同班,请你帮忙把同班的小朋友找出来。小朋友的编号为整数,与前一位小朋友同班用Y
表示,不同班用N
表示。
输入描述
输入为空格分开的小朋友编号和是否同班标志。
比如: 6/N
2/Y
3/N
4/Y
,表示共4
位小朋友,2
和6
同班, 3
和2
不同班,4
和3
同班。
其中,小朋友总数不超过999
,每个小朋友编号大于0
,小于等于999
。不考虑输入格式错误问题。
输出描述
输出为两行,每一行记录一个班小朋友的编号,编号用空格分开。
且:
- 编号需要按照大小升序排列,分班记录中第一个编号小的排在第一行;
- 若只有一个班的小朋友,第二行为空行;
- 若输入不符合要求,则直接输出字符串
ERROR
。
示例一
输入
6/N
2/Y
3/N
4/Y
输出
2 6
3 4
示例二
输入
2/N
3/Y
4/Y
输出
2 3 4
解题思路
每一个小朋友在哪个班,只跟其前一个小朋友在哪个班有关系。换句话说,考虑第i
个小朋友的分班,我们只需要关心第i-1
个小朋友在哪个班,而不需要关心第i-1
个小朋友为什么会分配到这个班。这是一种典型的dp
思路。
由于一共只有两个班,为了方便起见,我们分为1班和2班,同时默认第0
个小朋友位于1班。
我们考虑动态规划三部曲:
dp
数组的含义是什么?
dp
数组是一个长度为n
的一维列表,dp[i]
是布尔变量True
或者False
。如果dp[i] = True
表示第i
个小朋友分在1班dp[i] = False
表示第i
个小朋友分在2班
- 动态转移方程是什么?
dp[i]
只跟dp[i-1]
以及YN_lst[i]
有关系。若- 第
i
个小朋友和第i-1
个小朋友同班,即YN_lst[i] == "Y"
,那么dp[i] = dp[i-1]
- 第
i
个小朋友和第i-1
个小朋友不同班,即YN_lst[i] == "N"
,那么dp[i] = not dp[i-1]
- 第
if YN_lst[i] == "Y":dp[i] = dp[i-1]
elif YN_lst[i] == "N":dp[i] = not dp[i-1]
dp
数组如何初始化?
- 默认第
0
个小朋友是在1班,故dp[0] = True
做完dp过程之后,还需要依据题目要求,对两个班的小朋友进行排序和输出。其过程如下
class1, class2 = list(), list()
for i in range(n):class1.append(children_lst[i]) if dp[i] else class2.append(children_lst[i])class1.sort()
class2.sort()
if len(class2) == 0:print(" ".join(map(str, class1)))print("")
else:if class1[0] > class2[0]:class1, class2 = class2, class1print(" ".join(map(str, class1)))print(" ".join(map(str, class2)))
代码
Python
# 题目:2023B-分班
# 分值:100
# 作者:许老师-闭着眼睛学数理化
# 算法:DP
# 代码看不懂的地方,请直接在群上提问children_lst = list()
YN_lst = list()# 由于不知道输入行数,故使用try-except语句,结合while死循环进行输入
while True:# try语句,尝试执行以下语句try:# 进行输入s = input()# 如果s无法进行分割成两部分,则此处解包会出现报错,进入except语句child, ch = s.split("/")# 成功分割,则将小朋友编号记录在children_lst中# 是否与前一个小朋友同班的标记"Y"或"N"记录在YN_lst中children_lst.append(int(child))YN_lst.append(ch)# 如果出现错误,说明输入最后一行,退出死循环except:break# 获得小朋友的数目
n = len(children_lst)# 构建长度为n的dp数组,dp[i]的取值为True和False
# True表示第i个小朋友在1班,False表示第i个小朋友在2班
dp = [None] * n
# 初始化dp[0]为True,表示默认分配第0个小朋友在1班
dp[0] = True# 遍历所有小朋友
for i in range(1, n):# 如果YN_lst[i]为"Y",表示第i个小朋友和第i-1个小朋友同班# dp[i]和dp[i-1]取相同if YN_lst[i] == "Y":dp[i] = dp[i-1]# 如果YN_lst[i]为"N",表示第i个小朋友和第i-1个小朋友不同班# dp[i]和dp[i-1]取相反elif YN_lst[i] == "N":dp[i] = not dp[i-1]# 构建表示两个班级的列表
class1, class2 = list(), list()
for i in range(n):# 如果dp[i]为True,分到class1,如果dp[i]为False,分到class2class1.append(children_lst[i]) if dp[i] else class2.append(children_lst[i])# 题目要求排序,故对class1和class2进行排序
class1.sort()
class2.sort()
# 如果class2长度为0,说明所有小朋友都在1班
# 输出1班的结果和一个空字符串
if len(class2) == 0:print(" ".join(map(str, class1)))print("")
else:# 两个班级之间的排序,以班级中编号最小的小朋友为准# 故如果发现2班编号最小的小朋友比1班编号最小的小朋友更小# 应该先输出2班,故对两者进行交换if class1[0] > class2[0]:class1, class2 = class2, class1# 先输出1班,再输出2班print(" ".join(map(str, class1)))print(" ".join(map(str, class2)))
Java
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;public class Main {public static void main(String[] args) {List<Integer> childrenList = new ArrayList<>();List<String> ynList = new ArrayList<>();// 由于不知道输入行数,故使用 try-catch 语句,结合 while 死循环进行输入Scanner scanner = new Scanner(System.in);while (true) {// try 语句,尝试执行以下语句try {// 进行输入String s = scanner.nextLine();// 如果 s 无法进行分割成两部分,则此处解包会出现报错,进入 catch 语句String[] parts = s.split("/");int child = Integer.parseInt(parts[0]);String ch = parts[1];// 成功分割,则将小朋友编号记录在 childrenList 中// 是否与前一个小朋友同班的标记 "Y" 或 "N" 记录在 ynList 中childrenList.add(child);ynList.add(ch);}// 如果出现错误,说明输入最后一行,退出死循环catch (Exception e) {break;}}// 获得小朋友的数目int n = childrenList.size();// 构建长度为 n 的 dp 数组,dp[i] 的取值为 true 和 false// true 表示第 i 个小朋友在 1 班,false 表示第 i 个小朋友在 2 班boolean[] dp = new boolean[n];// 初始化 dp[0] 为 true,表示默认分配第 0 个小朋友在 1 班dp[0] = true;// 遍历所有小朋友for (int i = 1; i < n; i++) {// 如果 ynList[i] 为 "Y",表示第 i 个小朋友和第 i-1 个小朋友同班// dp[i] 和 dp[i-1] 取相同if (ynList.get(i).equals("Y")) {dp[i] = dp[i - 1];}// 如果 ynList[i] 为 "N",表示第 i 个小朋友和第 i-1 个小朋友不同班// dp[i] 和 dp[i-1] 取相反else if (ynList.get(i).equals("N")) {dp[i] = !dp[i - 1];}}// 构建表示两个班级的列表List<Integer> class1 = new ArrayList<>();List<Integer> class2 = new ArrayList<>();for (int i = 0; i < n; i++) {// 如果 dp[i] 为 true,分到 class1,如果 dp[i] 为 false,分到 class2if (dp[i]) {class1.add(childrenList.get(i));} else {class2.add(childrenList.get(i));}}// 题目要求排序,故对 class1 和 class2 进行排序class1.sort(Integer::compareTo);class2.sort(Integer::compareTo);// 如果 class2 长度为 0,说明所有小朋友都在 1 班// 输出 1 班的结果和一个空字符串if (class2.isEmpty()) {for (int child : class1) {System.out.print(child + " ");}System.out.println();System.out.println();} else {// 两个班级之间的排序,以班级中编号最小的小朋友为准// 故如果发现 2 班编号最小的小朋友比 1 班编号最小的小朋友更小// 应该先输出 2 班,故对两者进行交换if (class1.get(0) > class2.get(0)) {List<Integer> temp = class1;class1 = class2;class2 = temp;}// 先输出 1 班,再输出 2 班for (int child : class1) {System.out.print(child + " ");}System.out.println();for (int child : class2) {System.out.print(child + " ");}System.out.println();}}
}
C++
#include <iostream>
#include <vector>
#include <algorithm>using namespace std;int main() {vector<int> childrenList;vector<string> ynList;// 由于不知道输入行数,故使用 try-catch 语句,结合 while 死循环进行输入while (true) {// try 语句,尝试执行以下语句try {// 进行输入string s;getline(cin, s);// 如果 s 无法进行分割成两部分,则此处解包会出现报错,进入 catch 语句int pos = s.find('/');int child = stoi(s.substr(0, pos));string ch = s.substr(pos + 1);// 成功分割,则将小朋友编号记录在 childrenList 中// 是否与前一个小朋友同班的标记 "Y" 或 "N" 记录在 ynList 中childrenList.push_back(child);ynList.push_back(ch);}// 如果出现错误,说明输入最后一行,退出死循环catch (exception& e) {break;}}// 获得小朋友的数目int n = childrenList.size();// 构建长度为 n 的 dp 数组,dp[i] 的取值为 true 和 false// true 表示第 i 个小朋友在 1 班,false 表示第 i 个小朋友在 2 班vector<bool> dp(n);// 初始化 dp[0] 为 true,表示默认分配第 0 个小朋友在 1 班dp[0] = true;// 遍历所有小朋友for (int i = 1; i < n; i++) {// 如果 ynList[i] 为 "Y",表示第 i 个小朋友和第 i-1 个小朋友同班// dp[i] 和 dp[i-1] 取相同if (ynList[i] == "Y") {dp[i] = dp[i - 1];}// 如果 ynList[i] 为 "N",表示第 i 个小朋友和第 i-1 个小朋友不同班// dp[i] 和 dp[i-1] 取相反else if (ynList[i] == "N") {dp[i] = !dp[i - 1];}}// 构建表示两个班级的列表vector<int> class1, class2;for (int i = 0; i < n; i++) {// 如果 dp[i] 为 true,分到 class1,如果 dp[i] 为 false,分到 class2if (dp[i]) {class1.push_back(childrenList[i]);} else {class2.push_back(childrenList[i]);}}// 题目要求排序,故对 class1 和 class2 进行排序sort(class1.begin(), class1.end());sort(class2.begin(), class2.end());// 如果 class2 长度为 0,说明所有小朋友都在 1 班// 输出 1 班的结果和一个空行if (class2.empty()) {for (int child : class1) {cout << child << " ";}cout << endl << endl;} else {// 两个班级之间的排序,以班级中编号最小的小朋友为准// 故如果发现 2 班编号最小的小朋友比 1 班编号最小的小朋友更小// 应该先输出 2 班,故对两者进行交换if (class1[0] > class2[0]) {swap(class1, class2);}// 先输出 1 班,再输出 2 班for (int child : class1) {cout << child << " ";}cout << endl;for (int child : class2) {cout << child << " ";}cout << endl;}return 0;
}
时空复杂度
时间复杂度:O(xlogx + ylogy + N)
。O(xlogx)
和O(ylogy)
是两个班级各自排序的时间复杂度,O(N)
是dp过程的时间复杂度。
空间复杂度:O(N)
。
x
和y
为两个班级的人数,N
是总人数。
华为OD算法/大厂面试高频题算法练习冲刺训练
-
华为OD算法/大厂面试高频题算法冲刺训练目前开始常态化报名!目前已服务100+同学成功上岸!
-
课程讲师为全网50w+粉丝编程博主@吴师兄学算法 以及小红书头部编程博主@闭着眼睛学数理化
-
每期人数维持在20人内,保证能够最大限度地满足到每一个同学的需求,达到和1v1同样的学习效果!
-
60+天陪伴式学习,40+直播课时,300+动画图解视频,300+LeetCode经典题,200+华为OD真题/大厂真题,还有简历修改、模拟面试、专属HR对接将为你解锁
-
可上全网独家的欧弟OJ系统练习华子OD、大厂真题
-
可查看链接 大厂真题汇总 & OD真题汇总(持续更新)
-
绿色聊天软件戳
od1336
了解更多
相关文章:
【Py/Java/C++三种语言OD2023C卷真题】20天拿下华为OD笔试【DP】2023C-分班【欧弟算法】全网注释最详细分类最全的华为OD真题题解
文章目录 题目描述与示例题目描述输入描述输出描述示例一输入输出 示例二输入输出 解题思路代码PythonJavaC时空复杂度 华为OD算法/大厂面试高频题算法练习冲刺训练 题目描述与示例 题目描述 幼儿园两个班的小朋友在排队时混在了一起,每位小朋友都知道自己是否与前…...

pr模板哪个网站好?免费Pr模板视频素材下载网站 Prmuban.com
pr模板哪个网站好?哪里可以下载免费的pr模板视频素材,PR模板网(Prmuban.com)影视后期制作模板视频剪辑素材资源网站。 包含PR模板、PR插件、PR预设、MOGRT、LUT、转场特效、音乐素材、音效素材等,更好的剪辑师必备资源…...

【论文阅读】LoRA: Low-Rank Adaptation of Large Language Models
code:GitHub - microsoft/LoRA: Code for loralib, an implementation of "LoRA: Low-Rank Adaptation of Large Language Models" 做法: 把预训练LLMs里面的参数权重给冻结;向transformer架构中的每一层,注入可训练的…...
MybatisPlus的分页插件
PaginationInnerInterceptor 此插件是核心插件,目前代理了 Executor#query 和 Executor#update 和 StatementHandler#prepare 方法。 在SpringBoot环境中配置方式如下: /*** author giserDev* description 配置分页插件、方言、mapper包扫描等* date 2023-12-13 …...

保障网络安全:了解威胁检测和风险评分的重要性
在当今数字时代,网络安全问题变得愈发突出,而及时发现和迅速应对潜在威胁成为保障组织信息安全的首要任务。令人震惊的是,根据2023年的数据,平均而言,检测到一次网络入侵的时间竟然长达207天。这引起了对安全策略和技术…...

3D摄影棚布光:Set A Light 3D Studio
Set A Light 3D Studio是一款专业的灯光模拟软件,旨在帮助摄影师和电影制片人在电脑上进行虚拟灯光布置和场景模拟,以实现更加精准和高质量的拍摄效果。该软件提供了丰富的灯光和场景模型,支持灵活调整光源位置、强度、颜色和效果等参数&…...
#HarmonyOS:应用的包名配置--应用图标和标签配置--配置链接
配置相关 https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V2/application-component-configuration-stage-0000001478340869-V2 应用的包名配置 应用需要在工程的AppScope目录下的app.json5配置文件中配置bundleName标签,该标签用于标识应用的唯…...

docker小白第三天
docker小白第三天 docker为什么会比虚拟机快 1、docker有着比虚拟机更少的抽象层。不需要Hypervisor实现硬件资源虚拟化,运行在docker容器上的程序直接使用的都是实际物理机的硬件资源,因此在CPU、内存利用率上docker将会在效率上有明显优势。 2、dock…...
FFmpegd的AVBSF
本章主要介绍AVBSF 文章目录 结构体定义对外函数常见的过滤器 从名字我们可以知道这是个码流过滤器,我们最常用的是一个叫做h264_mp4toannexb_bsf的东东 这个过滤器的作用是把h264以MP4格式的NALU转换为annexb(0x000001) const AVBitStreamF…...

深圳三男子写字楼内吸烟被罚,快用富维AI神器,实时监控防火灾
最近,在深圳,一专项控烟督查组在福田区新华保险大厦发现三名男子在写字楼内楼道违法吸烟,并对其进行了现场处罚。根据《控烟条例》,这类室内区域严禁吸烟,但人们往往忽视这一规定,从而引发潜在的安全风险。…...

有哪些已经上线的vue商城项目?
前言 下面是一些商城的项目,需要练手的同学可以挑选一些来练,废话少说,让我们直接开始正题~~ 1、newbee-mall-vue3-app 是一个基于 Vue 3 和 TypeScript 的电商前端项目,它是 newbee-mall 项目的升级版。该项目包含了商品列表、…...

Nginx服务器配置SSL证书
本文将全面介绍如何在Nginx或Tengine服务器配置SSL证书,具体包括下载和上传证书文件,在Nginx上配置证书文件、证书链和证书密钥等参数,以及安装证书后结果的验证。成功配置SSL证书后,您将能够通过HTTPS加密通道安全访问Nginx服务器…...

【JVM从入门到实战】(六)类加载器的双亲委派机制
一、双亲委派机制 在Java中如何使用代码的方式去主动加载一个类呢? 方式1:使用Class.forName方法,使用当前类的类加载器去加载指定的类。 方式2:获取到类加载器,通过类加载器的loadClass方法指定某个类加载器加载。 …...

SpringCloud面试题及答案(最新50道大厂版,持续更新)
在Java开发中,Spring Cloud作为微服务架构的关键组成部分,为了帮助广大Java技术爱好者和专业开发人员深入理解Spring Cloud,本文《SpringCloud面试题及答案(最新50道大厂版,持续更新)》提供了最前沿、最实用…...
Next.js 的设计理念
Next.js 的设计理念:简洁、强大与高效 Next.js 是一个流行的 React 框架,由 Vercel 公司开发。它的设计理念是简洁、强大和高效,这种理念贯穿于 Next.js 的所有功能中。下面我们将深入探讨这三个设计理念。 简洁 Next.js 的一个核心设计理…...

26、文件包含
文章目录 一、文件包含1.1 概念1.2 PHP文件包含原理1.3 文件包含重要函数1.4 文件包含利用条件 二、文件包含漏洞利用2.1 文件包含分类2.2 常见敏感文件2.3 包含Apache日志文件2.4 常见中间件的日志路径2.5 包含其他日志文件2.5.1 SSH日志文件2.5.2 Session文件 三、PHP封装伪协…...

飞天使-linux操作的一些技巧与知识点4-ansible常用的技巧,配置等
文章目录 ansible配置文件的优先级尝试开始进行操作ansible常用模块ansible 的playbook示例安装phpplaybook中变量的引用 ansible yum install -y ansible 测试是否可用 ansible localhost -m ping /etc/ansible/ansible.cfg :主配置文件,配置 ansible…...

Stable Diffusion 源码解析(1)
参考1:https://blog.csdn.net/Eric_1993/article/details/129393890 参考2:https://zhuanlan.zhihu.com/p/613337342 1.StableDiffusion基本原理1.1 UNetModel、FrozenCLIP 模型1.2 DDPM、DDIM、PLMS算法 2. Runwayml SD 源码2.1 Img2Img Pipeline2.2 DD…...
java.lang.ClassNotFoundException:javax.xml.bind.DatatypeConverter 报错解决
问题原因: 这有可能是因为SpringBoot项目结合jwt进行用户登录时出现的问题,因为jdk版本太高导致的 解决办法: 方法一: 降低jdk版本 检查JDK版本,如果你是JDK17版本,就降到JDK8版本 方案二:在meven中添加依赖 注意: 如果2.3.1的版本不生效,则使用2.3.0的版本 <…...

Python学习笔记-类
1 定义类 类是函数的集合,class来定义类 pass并没有实际含义,只是为了代码能执行通过,不报错而已,相当于在代码种占一个位置,后续完善 类是对象的加工厂 2.创建对象 carCar()即是创建对象的过程 3、类的成员 3.1 实例…...

IDEA运行Tomcat出现乱码问题解决汇总
最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…...
云计算——弹性云计算器(ECS)
弹性云服务器:ECS 概述 云计算重构了ICT系统,云计算平台厂商推出使得厂家能够主要关注应用管理而非平台管理的云平台,包含如下主要概念。 ECS(Elastic Cloud Server):即弹性云服务器,是云计算…...
系统设计 --- MongoDB亿级数据查询优化策略
系统设计 --- MongoDB亿级数据查询分表策略 背景Solution --- 分表 背景 使用audit log实现Audi Trail功能 Audit Trail范围: 六个月数据量: 每秒5-7条audi log,共计7千万 – 1亿条数据需要实现全文检索按照时间倒序因为license问题,不能使用ELK只能使用…...

Cinnamon修改面板小工具图标
Cinnamon开始菜单-CSDN博客 设置模块都是做好的,比GNOME简单得多! 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...

华为OD机试-食堂供餐-二分法
import java.util.Arrays; import java.util.Scanner;public class DemoTest3 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseint a in.nextIn…...

从零实现STL哈希容器:unordered_map/unordered_set封装详解
本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说,直接开始吧! 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...

分布式增量爬虫实现方案
之前我们在讨论的是分布式爬虫如何实现增量爬取。增量爬虫的目标是只爬取新产生或发生变化的页面,避免重复抓取,以节省资源和时间。 在分布式环境下,增量爬虫的实现需要考虑多个爬虫节点之间的协调和去重。 另一种思路:将增量判…...
Caliper 配置文件解析:fisco-bcos.json
config.yaml 文件 config.yaml 是 Caliper 的主配置文件,通常包含以下内容: test:name: fisco-bcos-test # 测试名称description: Performance test of FISCO-BCOS # 测试描述workers:type: local # 工作进程类型number: 5 # 工作进程数量monitor:type: - docker- pro…...

Unity UGUI Button事件流程
场景结构 测试代码 public class TestBtn : MonoBehaviour {void Start(){var btn GetComponent<Button>();btn.onClick.AddListener(OnClick);}private void OnClick(){Debug.Log("666");}}当添加事件时 // 实例化一个ButtonClickedEvent的事件 [Formerl…...

企业大模型服务合规指南:深度解析备案与登记制度
伴随AI技术的爆炸式发展,尤其是大模型(LLM)在各行各业的深度应用和整合,企业利用AI技术提升效率、创新服务的步伐不断加快。无论是像DeepSeek这样的前沿技术提供者,还是积极拥抱AI转型的传统企业,在面向公众…...