【限时免费】20天拿下华为OD笔试之【哈希表】2023Q2B-选修课【欧弟算法】全网注释最详细分类最全的华为OD真题题解
文章目录
- 题目描述与示例
- 题目描述
- 输入
- 输出
- 示例一
- 输入
- 输出
- 说明
- 示例二
- 输入
- 输出
- 说明
- 解题思路
- 代码
- Python
- Java
- C++
- 时空复杂度
- 华为OD算法/大厂面试高频题算法练习冲刺训练
题目描述与示例
题目描述
现有两门选修课,每门选修课都有一部分学生选修,每个学生都有选修课的成绩,需要你找出同时选修了两门选修课的学生,先按照班级进行划分,班级编号小的先输出,每个班级按照两门选修课成绩和的降序排序,成绩相同时按照学生的学号升序排序。
输入
第一行为第一门选修课学生的成绩,第二行为第二门选修课学生的成绩,每行数据中学生之间以英文分号分隔,每个学生的学号和成绩以英文逗号分隔,学生学号的格式为 8
位数字(2
位院系编号+入学年份后 2
位+院系内部 1
位专业编号+所在班级 3
位学号),学生成绩的取值范围为 [0,100]
之间的整数,两门选修课选修学生数的取值范围为 [1-2000]
之间的整数。
输出
同时选修了两门选修课的学生的学号,如果没有同时选修两门选修课的学生输出 NULL
,否则,先按照班级划分,班级编号小的先输出,每个班级先输出班级编号(学号前五位),然后另起一行输出这个班级同时选修两门选修课的学生学号,学号按照要求排序(按照两门选修课成绩和的降序,成绩和相同时按照学号升序),学生之间以英文分号分隔。
示例一
输入
01202021,75;01201033,95;01202008,80;01203006,90;01203088,100
01202008,70;01203088,85;01202111,80;01202021,75;01201100,88
输出
01202
01202008;01202021
01203
01203088
说明
同时选修了两门选修课的学生 01202021
、01202008
、01203088
,这三个学生两门选修课的成绩和分别为 150
、150
、185
。01202021
、01202008
属于 01202
班的学生,按照成绩和降序,成绩相同时按学号升序输出的结果为 01202008;01202021
。01203088
属于 01203
班的学生,按照成绩和降序,成绩相同时按学号升序输出的结果为 01203088
。01202
的班级编号小于 01203
的班级编号,需要先输出。
示例二
输入
01201022,75;01202033,95;01202018,80;01203006,90;01202066,100
01202008,70;01203102,85;01202111,80;01201021,75;01201100,88
输出
NULL
说明
没有同时选修了两门选修课的学生,输出 NULL
。
解题思路
这题属于典型的哈希表和排序的应用,难度不大。但题干较长,需要仔细读题并理解题目含义。由于分了多层的排序,因此代码也比较长,需要写题时对问题时刻保持清晰的头脑。
代码
Python
# 题目:2023Q2B-选修课
# 分值:100
# 作者:许老师-闭着眼睛学数理化
# 算法:哈希表,排序
# 代码看不懂的地方,请直接在群上提问from collections import defaultdict# 定义根据传入的lst构建哈希表的函数
def buildDict(lst):# 初始化一个空哈希表dicdic = dict()# 遍历lst中的每一个字符串元素itemfor item in lst:# item中用","隔开学号和成绩num, grade = item.split(",")# 以学号num为key,成绩int(grade)为value,存入哈希表dic中dic[num] = int(grade)# 哈希表dic构建完毕,返回dicreturn dic# 分别输入两行字符串,表示两门选修课情况,
# 对字符串根据";"进行分割,存入两个列表中
lst1 = input().split(";")
lst2 = input().split(";")# 根据两个列表,构建两个字典分别表示选修课1和2的选课情况
# 字典中的key为学号,value为成绩
dic1 = buildDict(lst1)
dic2 = buildDict(lst2)# 由于要统计两门选修课均选了的学生的成绩情况,使用字典推导式构建一个新字典dic_total
# dic_total的key为学号,value为两门选修课成绩的和
dic_total = {num: (dic1[num] + dic2[num]) for num in dic1 if num in dic2}# 如果dic_total长度为0,说明没有任何一个学生同时选了两门选修课
# 按照题意直接输出"NULL"
if len(dic_total) == 0:print("NULL")
# 否则可以进行后续的排序和输出
else:# 构建一个新的字典用于储存特定班级所包含的学生# key为5位的班级编号,value为储存若干学号的列表dic_class = defaultdict(list)for num in dic_total:# 学号的前5位为班级编号class_num = num[:5]dic_class[class_num].append(num)# 遍历dic_class排序后的key,即为班级编号for class_num in sorted(dic_class.keys()):# 先输出班级print(class_num)# 获得班级class_num的所有学号num_lst = dic_class[class_num]# 对num_lst进行排序# 先按照成绩降序排列,即根据-dic_total[x]升序排列# 成绩相同时再按照学号排列,即根据x排列num_lst.sort(key = lambda x: (-dic_total[x], x))# 输出该班级中排序后的学生学号print(";".join(num_lst))
Java
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;/*2023Q2B-选修课*/
public class Main {public static void main(String[] args) throws IOException {BufferedReader br = new BufferedReader(new InputStreamReader(System.in));String course1 = br.readLine();String course2 = br.readLine();String[] split1 = course1.split(";");String[] split2 = course2.split(";");HashMap<String, Integer> hashMap1 = new HashMap<>();HashMap<String, Integer> hashMap2 = new HashMap<>();String[] cur;for (String s : split1) {cur = s.split(",");hashMap1.put(cur[0],Integer.parseInt(cur[1]));}HashMap<String,List<String>> result = new HashMap<>();String classNum;for (String s : split2){cur = s.split(",");hashMap2.put(cur[0],Integer.parseInt(cur[1]));if (hashMap1.containsKey(cur[0])){classNum = cur[0].substring(0,5);if(!result.containsKey(classNum)){List<String> stuList = new ArrayList<>();stuList.add(cur[0]);result.put(classNum,stuList);}else {result.get(classNum).add(cur[0]);}}}if(result.isEmpty()){System.out.println("NULL");}List<String> classList = new ArrayList<>(result.keySet());//班级编号小的先输出Collections.sort(classList);for (String cla : classList) {//输出班级编号System.out.println(cla);//根据班级编号获取学生列表List<String> stuList = result.get(cla);//按照学号升序Collections.sort(stuList);//按照两门选修课成绩和的降序Collections.sort(stuList,((o1, o2) -> (hashMap1.get(o2)+hashMap2.get(o2))-(hashMap1.get(o1)+hashMap2.get(o1))));//注意,每一次输出学生学号都要新建一个sj,否则包含之前sj的结果导致输出错误.StringJoiner sj = new StringJoiner(";");for (String stu : stuList) {sj.add(stu);}//输出学生学号System.out.println(sj);}}
}
C++
#include <iostream>
#include <sstream>
#include <unordered_map>
#include <vector>
#include <algorithm>using namespace std;unordered_map<string, int> buildDict(const vector<string>& lst) {unordered_map<string, int> dic;for (const string& item : lst) {stringstream ss(item);string num, gradeStr;getline(ss, num, ',');getline(ss, gradeStr, ',');int grade = stoi(gradeStr);dic[num] = grade;}return dic;
}int main() {string course1, course2;getline(cin, course1);getline(cin, course2);stringstream ss1(course1), ss2(course2);vector<string> lst1, lst2;string token;while (getline(ss1, token, ';')) {lst1.push_back(token);}while (getline(ss2, token, ';')) {lst2.push_back(token);}unordered_map<string, int> dic1 = buildDict(lst1);unordered_map<string, int> dic2 = buildDict(lst2);unordered_map<string, vector<string>> result;for (const auto& entry : dic2) {if (dic1.find(entry.first) != dic1.end()) {string classNum = entry.first.substr(0, 5);result[classNum].push_back(entry.first);}}if (result.empty()) {cout << "NULL" << endl;} else {vector<string> classList;for (const auto& entry : result) {classList.push_back(entry.first);}sort(classList.begin(), classList.end());for (const string& cls : classList) {cout << cls << endl;vector<string> stuList = result[cls];sort(stuList.begin(), stuList.end(), [&](const string& a, const string& b) {int sumA = dic1[a] + dic2[a];int sumB = dic1[b] + dic2[b];if (sumA != sumB) {return sumA > sumB;}return a < b;});for (size_t i = 0; i < stuList.size(); ++i) {cout << stuList[i];if (i != stuList.size() - 1) {cout << ";";}}cout << endl;}}return 0;
}
时空复杂度
时间复杂度:O(NlogN)
。排序所需的时间复杂度。
空间复杂度:O(N)
。哈希表所占的额外空间。
华为OD算法/大厂面试高频题算法练习冲刺训练
-
华为OD算法/大厂面试高频题算法冲刺训练目前开始常态化报名!目前已服务100+同学成功上岸!
-
课程讲师为全网50w+粉丝编程博主@吴师兄学算法 以及小红书头部编程博主@闭着眼睛学数理化
-
每期人数维持在20人内,保证能够最大限度地满足到每一个同学的需求,达到和1v1同样的学习效果!
-
60+天陪伴式学习,40+直播课时,300+动画图解视频,300+LeetCode经典题,200+华为OD真题/大厂真题,还有简历修改、模拟面试、专属HR对接将为你解锁
-
可上全网独家的欧弟OJ系统练习华子OD、大厂真题
-
可查看链接 大厂真题汇总 & OD真题汇总(持续更新)
-
绿色聊天软件戳
od1336
了解更多
相关文章:
【限时免费】20天拿下华为OD笔试之【哈希表】2023Q2B-选修课【欧弟算法】全网注释最详细分类最全的华为OD真题题解
文章目录 题目描述与示例题目描述输入输出示例一输入输出说明 示例二输入输出说明 解题思路代码PythonJavaC时空复杂度 华为OD算法/大厂面试高频题算法练习冲刺训练 题目描述与示例 题目描述 现有两门选修课,每门选修课都有一部分学生选修,每个学生都有…...

Android关于杀掉进程的方案
《风波莫听穿林打叶声》—— 苏轼 〔宋代〕 三月七日,沙湖道中遇雨,雨具先去,同行皆狼狈,余独不觉。已而遂晴,故作此词。 莫听穿林打叶声,何妨吟啸且徐行。 竹杖芒鞋轻胜马,谁怕?一蓑…...
mysql数据库基本概念简介
概述 为什么要使用数据库? 答:实现数据的持久化。 数据库存储类型多样,存储量大。由于其他文件等介质。 概念 DB:database(数据库),保存数据的仓库,本质是一个文件系统。 DBMS:数据库管理系统,常说的Mysql数…...

前端开发_HTML
简介 CSS用于美化内容 HTML用于摆放内容 可以理解为HTML是基础,CSS是工具 HTML定义 HTML 超文本标记语言——HyperText Markup Language 超文本——链接 标记——标签,即带尖括号的文本 标签语法 双标签 开始标签: <xxx> 即尖…...

1.Spring源码解析-ClassPathXmlApplicationContext
此类是读取spring的xml配置文件并解析。也是源码入口之一。 我们调试即将开始。 传递给父类设置值 经调试我们得到是给AbstractApplicationContext设置默认的应用上下文父级的值,很明显是空 给父类AbstractRefreshableConfigApplicationContext设置属性 刷新容器…...
android 动态创建selector状态选择器 动态创建Drawable
最近在做一个使用接口返回的字符串:"#ff0000" 来动态设置drawable背景颜色与动态设置状态选择器selector的需求,之前写习惯了shape的xml,还是第一次写动态的,有点搞笑,搞笑的是自己没写过,不知道…...
Python与设计模式--责任链模式
23种计模式之 前言 (5)单例模式、工厂模式、简单工厂模式、抽象工厂模式、建造者模式、原型模式、(7)代理模式、装饰器模式、适配器模式、门面模式、组合模式、享元模式、桥梁模式、(11)策略模式、责任链模式、命令模式、中介者模…...
(C)一些题6
1.正确定义符号常量PI的宏定义为 A.define PI 3.14 B.define PI 3.14: C。#define PI 3.14 D #define PI 3.14; 2。关于字符数组的描述中错误的是() A.字符数组可以存放字符串 B.字符数组中的字符串可以整体输入和输出 C。可以在赋值语句中通过运算符“”对…...

基于单片机的肺活量检测系统(论文+源码)
1.系统设计 在基于单片机的肺活量检测系统中,在硬件上整个系统通过利用主控制器STC89C52单片机来实现对整个系统进行控制的功能,通过采用LCD1602实现实时液晶显示数据的功能,通过肺活量传感器XGZP6847ADC0832实现监测肺活量的工作࿰…...

【开题报告】海洋多源数据质量控制应用服务的WebServer设计与实现
开 题 报 告 内 容 论文选题的意义、主要研究内容和文献资料调研情况 一、选题意义 在当今世界研究自然环境的大背景下,计算机技术与各学科、各领域的综合应用逐渐增多。作为地球上最广阔的水体,同时也是地球上决定气候发展的主要的因素之一࿰…...

接单平台在精不在多,劝诸位程序员找个好平台!
程序员想找兼职搞副业,结果知乎上逛了一大圈,各种平台推荐,可以说是眼花缭乱。要么就是平台一搜,各种劝退!好好好,就问一句,还搞不搞?Of course~有钱还不赚的是傻子。加班摸鱼的时候…...

mybatis关于namespace以及id以及Mapper接口命名的说明(了解)
1、建库建表 CREATE DATABASE mybatis-example;USE mybatis-example;CREATE TABLE t_emp(emp_id INT AUTO_INCREMENT,emp_name CHAR(100),emp_salary DOUBLE(10,5),PRIMARY KEY(emp_id) );INSERT INTO t_emp(emp_name,emp_salary) VALUES("tom",200.33); INSERT INTO…...
MySQL中的锁(简单)
目录 1. 共享锁(Shared Lock): 2. 排他锁(Exclusive Lock): 3. 行级锁(Row-Level Lock): 4. 页级锁(Page-Level Lock): 5. 表级锁…...
【独家OD2023C卷真题】20天拿下华为OD笔试【贪心】2023C-分配土地最大面积【欧弟算法】全网注释最详细分类最全的华为OD真题题解
文章目录 题目描述与示例题目描述输入描述输出描述备注示例一输入输出说明 示例二输入输出说明 解题思路单种颜色的最小覆盖面积多种颜色的最小覆盖面积 代码PythonJavaC时空复杂度 华为OD算法/大厂面试高频题算法练习冲刺训练 题目描述与示例 题目描述 从前有个村庄…...
省市区编码sql
CREATE TABLE area (id bigint(20) NOT NULL AUTO_INCREMENT COMMENT 主键,code varchar(64) COLLATE utf8mb4_bin DEFAULT NULL COMMENT 编码,name varchar(255) COLLATE utf8mb4_bin DEFAULT NULL COMMENT 名称,parent_code varchar(64) COLLATE utf8mb4_bin DEFAULT NULL CO…...

实现电商平台与营销系统无缝集成:雅座的无代码开发与API连接
无代码开发:营销的新引擎 在数字化转型的浪潮中,无代码开发已成为企业提升效率、减少成本的新引擎。这种开发方式允许非技术人员通过图形界面构建应用程序,无需编写代码即可实现复杂功能。这对于营销、广告推广以及用户运营等业务尤为重要&a…...

win10下安装 Anaconda + Cuda + Cudnn + Pycharm + Pytorch
1.安装Anaconda (1-1)下载Ananconda, Anaconda官网 选择windows版本; (1-2)安装Anaconda,一般选择【Just Me】 (1-3)建议不要装在C盘,后期多环境的python环境和各种库文件会占用很多…...

第20章 多线程
创建线程 继承Thread 类 Thread 类时 java.lang 包中的一个类,从类中实例化的对象代表线程,程序员启动一个新线程需要建立 Thread 实例。 Thread 对象需要一个任务来执行,任务是指线程在启动时执行的工作,start() 方法启动线程&am…...

自定义类型:结构体,枚举,联合
1结构体的声明 1.1结构体基础知识 结构是一些值的集合,这些值称为成员变量。结构的每个成员可以是不同类型的变量。 1.2声明: struct tag {member-list; }variable-list; 描述一个学生: struct Stu {char name[20];//名字int age;//年龄char…...

C++:C++11新特性---右值引用
文章目录 初始化方式显示查看类型initializer_listdecltype左值引用和右值引用move左右值引用的场景 万能引用和完美转发 本篇总结C11新特性 初始化方式 C11对参数列表的初始化有了更明确的定义,可以这样进行定义 // 列表初始化 void test1() {// 旧版本int x 0…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...
uniapp中使用aixos 报错
问题: 在uniapp中使用aixos,运行后报如下错误: AxiosError: There is no suitable adapter to dispatch the request since : - adapter xhr is not supported by the environment - adapter http is not available in the build 解决方案&…...

Yolov8 目标检测蒸馏学习记录
yolov8系列模型蒸馏基本流程,代码下载:这里本人提交了一个demo:djdll/Yolov8_Distillation: Yolov8轻量化_蒸馏代码实现 在轻量化模型设计中,**知识蒸馏(Knowledge Distillation)**被广泛应用,作为提升模型…...

【Linux系统】Linux环境变量:系统配置的隐形指挥官
。# Linux系列 文章目录 前言一、环境变量的概念二、常见的环境变量三、环境变量特点及其相关指令3.1 环境变量的全局性3.2、环境变量的生命周期 四、环境变量的组织方式五、C语言对环境变量的操作5.1 设置环境变量:setenv5.2 删除环境变量:unsetenv5.3 遍历所有环境…...

Kubernetes 节点自动伸缩(Cluster Autoscaler)原理与实践
在 Kubernetes 集群中,如何在保障应用高可用的同时有效地管理资源,一直是运维人员和开发者关注的重点。随着微服务架构的普及,集群内各个服务的负载波动日趋明显,传统的手动扩缩容方式已无法满足实时性和弹性需求。 Cluster Auto…...

sshd代码修改banner
sshd服务连接之后会收到字符串: SSH-2.0-OpenSSH_9.5 容易被hacker识别此服务为sshd服务。 是否可以通过修改此banner达到让人无法识别此服务的目的呢? 不能。因为这是写的SSH的协议中的。 也就是协议规定了banner必须这么写。 SSH- 开头,…...
TJCTF 2025
还以为是天津的。这个比较容易,虽然绕了点弯,可还是把CP AK了,不过我会的别人也会,还是没啥名次。记录一下吧。 Crypto bacon-bits with open(flag.txt) as f: flag f.read().strip() with open(text.txt) as t: text t.read…...
在ubuntu等linux系统上申请https证书
使用 Certbot 自动申请 安装 Certbot Certbot 是 Let’s Encrypt 官方推荐的自动化工具,支持多种操作系统和服务器环境。 在 Ubuntu/Debian 上: sudo apt update sudo apt install certbot申请证书 纯手动方式(不自动配置)&…...

可视化预警系统:如何实现生产风险的实时监控?
在生产环境中,风险无处不在,而传统的监控方式往往只能事后补救,难以做到提前预警。但如今,可视化预警系统正在改变这一切!它能够实时收集和分析生产数据,通过直观的图表和警报,让管理者第一时间…...
SQL 注入开放与修复
开发: SQL 注入是一种数据库攻击手段。攻击者通过向应用程序提交恶意代码来改变原 SQL 语句的含义, 进而执行任意 SQL 命令,达到入侵数据库乃至操作系统的目的。 例如:下面代码片段中,动态构造并执行了一个 SQ…...