【限时免费】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…...
以下是对华为 HarmonyOS NETX 5属性动画(ArkTS)文档的结构化整理,通过层级标题、表格和代码块提升可读性:
一、属性动画概述NETX 作用:实现组件通用属性的渐变过渡效果,提升用户体验。支持属性:width、height、backgroundColor、opacity、scale、rotate、translate等。注意事项: 布局类属性(如宽高)变化时&#…...
3.3.1_1 检错编码(奇偶校验码)
从这节课开始,我们会探讨数据链路层的差错控制功能,差错控制功能的主要目标是要发现并且解决一个帧内部的位错误,我们需要使用特殊的编码技术去发现帧内部的位错误,当我们发现位错误之后,通常来说有两种解决方案。第一…...
linux 错误码总结
1,错误码的概念与作用 在Linux系统中,错误码是系统调用或库函数在执行失败时返回的特定数值,用于指示具体的错误类型。这些错误码通过全局变量errno来存储和传递,errno由操作系统维护,保存最近一次发生的错误信息。值得注意的是,errno的值在每次系统调用或函数调用失败时…...
Android 之 kotlin 语言学习笔记三(Kotlin-Java 互操作)
参考官方文档:https://developer.android.google.cn/kotlin/interop?hlzh-cn 一、Java(供 Kotlin 使用) 1、不得使用硬关键字 不要使用 Kotlin 的任何硬关键字作为方法的名称 或字段。允许使用 Kotlin 的软关键字、修饰符关键字和特殊标识…...
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…...
python爬虫——气象数据爬取
一、导入库与全局配置 python 运行 import json import datetime import time import requests from sqlalchemy import create_engine import csv import pandas as pd作用: 引入数据解析、网络请求、时间处理、数据库操作等所需库。requests:发送 …...
Kafka主题运维全指南:从基础配置到故障处理
#作者:张桐瑞 文章目录 主题日常管理1. 修改主题分区。2. 修改主题级别参数。3. 变更副本数。4. 修改主题限速。5.主题分区迁移。6. 常见主题错误处理常见错误1:主题删除失败。常见错误2:__consumer_offsets占用太多的磁盘。 主题日常管理 …...
从物理机到云原生:全面解析计算虚拟化技术的演进与应用
前言:我的虚拟化技术探索之旅 我最早接触"虚拟机"的概念是从Java开始的——JVM(Java Virtual Machine)让"一次编写,到处运行"成为可能。这个软件层面的虚拟化让我着迷,但直到后来接触VMware和Doc…...
DiscuzX3.5发帖json api
参考文章:PHP实现独立Discuz站外发帖(直连操作数据库)_discuz 发帖api-CSDN博客 简单改造了一下,适配我自己的需求 有一个站点存在多个采集站,我想通过主站拿标题,采集站拿内容 使用到的sql如下 CREATE TABLE pre_forum_post_…...
aardio 自动识别验证码输入
技术尝试 上周在发学习日志时有网友提议“在网页上识别验证码”,于是尝试整合图像识别与网页自动化技术,完成了这套模拟登录流程。核心思路是:截图验证码→OCR识别→自动填充表单→提交并验证结果。 代码在这里 import soImage; import we…...
