华为OD机试真题—— 流水线(2025B卷:100分)Java/python/JavaScript/C/C++/GO最佳实现
2025 B卷 100分 题型
本专栏内全部题目均提供Java、python、JavaScript、C、C++、GO六种语言的最佳实现方式;
并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析;
本文收录于专栏:《2025华为OD真题目录+全流程解析+备考攻略+经验分享》
华为OD机试真题《流水线》:
文章快捷目录
题目描述及说明
Java
python
JavaScript
C++
C
GO
题目名称:流水线
知识点:排序、贪心算法(最小堆)
时间限制:1秒
空间限制:256MB
限定语言:不限
题目描述
一个工厂有 m
条流水线,用于并行完成 n
个独立作业。调度系统在安排作业时,优先执行处理时间最短的作业。
当 n > m
时,处理时间最短的 m
个作业先进入流水线,其余作业等待。当某流水线作业完成后,从剩余作业中选择最短的补入。
要求计算处理完所有作业的总耗时。
输入描述
- 第一行为两个整数(空格分隔),表示流水线个数
m
和作业数n
。 - 第二行为
n
个整数(空格分隔),表示每个作业的处理时长t1, t2, ..., tn
。 - 取值范围:
0 < m, n < 100
,0 < t1, t2...tn < 100
。
输出描述
输出处理完所有作业的总时长。
示例
输入
3 5
8 4 3 2 10
输出
13
说明
- 初始分配最短的 3 个作业
2,3,4
进入流水线。 - 流水线1完成时间
2
,补入剩余最短作业8
。 - 流水线2完成时间
3
,补入剩余作业10
。 - 最终最长耗时为
3 + 10 = 13
。
Java
问题分析
我们需要调度多个作业到流水线,使得总耗时最短。每个流水线同一时间只能处理一个作业,且优先分配给处理时间最短的作业。总耗时由所有流水线中耗时最长的决定。
解题思路
- 排序作业:先将所有作业按处理时间从小到大排序。
- 贪心分配:使用最小堆模拟流水线,每次选择当前总时间最小的流水线,分配下一个最短作业。
- 计算总耗时:最后所有流水线的总时间中的最大值即为答案。
代码实现
import java.util.*;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int m = scanner.nextInt(); // 流水线数量int n = scanner.nextInt(); // 作业数量int[] tasks = new int[n]; // 存储每个作业的处理时间for (int i = 0; i < n; i++) {tasks[i] = scanner.nextInt();}Arrays.sort(tasks); // 按处理时间升序排列PriorityQueue<Integer> pq = new PriorityQueue<>(); // 最小堆,存储各流水线当前总时间int initialJobs = Math.min(m, n); // 初始分配的作业数(不超过流水线数)for (int i = 0; i < initialJobs; i++) {pq.add(tasks[i]); // 初始作业分配给流水线}// 处理剩余的作业(当n > m时)for (int i = m; i < n; i++) {int earliestEnd = pq.poll(); // 取出当前最早空闲的流水线earliestEnd += tasks[i]; // 分配新作业到该流水线pq.add(earliestEnd); // 将新总时间重新加入堆}// 找到堆中的最大总时间,即为总耗时int maxTime = 0;while (!pq.isEmpty()) {maxTime = Math.max(maxTime, pq.poll());}System.out.println(maxTime);}
}
代码解析
- 输入处理:读取流水线数
m
、作业数n
及每个作业的处理时间存入数组。 - 排序作业:将作业按处理时间从小到大排序,确保优先分配最短作业。
- 初始化堆:将前
m
个(或全部作业如果少于m
)作业直接加入最小堆,表示初始分配的流水线时间。 - 处理剩余作业:对于后续作业,每次从堆中取出当前总时间最小的流水线,加上新作业时间后重新插入堆,动态调整流水线负载。
- 计算总耗时:遍历堆中的总时间,取最大值即为所有作业完成的总耗时。
示例测试
示例输入1:
3 5
8 4 3 2 10
输出1:13
解析:初始分配 2、3、4 → 流水线时间 [2,3,4]。剩余作业 8 → 2+8=10,队列变为 [3,4,10]。作业 10 → 3+10=13,队列变为 [4,10,13]。最大时间为13。
示例输入2:
2 4
1 2 3 4
输出2:6
解析:初始分配 1、2 → 流水线时间 [1,2]。剩余作业 3 → 1+3=4,队列 [2,4]。作业4 → 2+4=6。最大时间6。
示例输入3:
5 3
5 3 1
输出3:5
解析:初始分配 1、3、5 → 最大时间5(无需处理后续作业)。
综合分析
- 时间复杂度:O(n log n) 来自排序,O(n log m) 来自堆操作,总体 O(n log n)。
- 空间复杂度:O(m) 用于存储堆,m ≤ 100,空间高效。
- 贪心选择正确性:每次选择最短作业分配到最早空闲流水线,确保总耗时最小。
- 适用性:适用于作业调度、资源分配等场景,高效处理大规模数据。
python
问题分析
本问题要求将多个作业调度到流水线,使得所有作业完成的总时间最短。流水线按处理时间最短优先分配作业,总耗时由最长完成时间的流水线决定。
解题思路
- 排序作业:将作业按处理时间从小到大排序,确保优先分配最短作业。
- 贪心调度:使用最小堆维护当前流水线的完成时间,每次选取最早空闲的流水线分配新的最短作业。
- 计算总耗时:最终所有流水线的完成时间中的最大值即为答案。
代码实现
import heapqdef main():# 读取输入m, n = map(int, input().split())tasks = list(
相关文章:

华为OD机试真题—— 流水线(2025B卷:100分)Java/python/JavaScript/C/C++/GO最佳实现
2025 B卷 100分 题型 本专栏内全部题目均提供Java、python、JavaScript、C、C++、GO六种语言的最佳实现方式; 并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析; 本文收录于专栏:《2025华为OD真题目录+全流程解析+备考攻略+经验分…...

【数据架构01】数据技术架构篇
✅ 9张高质量数据架构图:大数据平台功能架构、数据全生命周期管理图、AI技术融合架构等; 🚀无论你是数据架构师、治理专家,还是数字化转型负责人,这份资料库都能为你提供体系化参考,高效解决“架构设计难、…...
【安全攻防与漏洞】HTTPS中的常见攻击与防御
HTTPS 中常见攻击与防御策略涵盖中间人攻击(MITM)、SSL剥离、重放攻击等,帮助构建安全的 HTTPS 通信环境: 一、中间人攻击(MITM) 攻击原理 场景:攻击者通过伪造证书或劫持网络流量,…...
esp32cmini SK6812 2个方式
1 #include <SPI.h> // ESP32-C系列的SPI引脚 #define MOSI_PIN 7 // ESP32-C3/C6的SPI MOSI引脚 #define NUM_LEDS 30 // LED灯带实际LED数量 - 确保与实际数量匹配! #define SPI_CLOCK 10000000 // SPI时钟频率 // 颜色结构体 st…...

【数据集】30 m地表温度LST数据集
目录 数据概述🔧研究目标与意义🧠 算法核心组成1. 地表比辐射率(LSE)估算2. 大气校正(Atmospheric Correction)LST反演流程图📊 精度验证与评估结果参考《Generating the 30-m land surface temperature product over continental China and USA from Landsat 5/7/8 …...

【CATIA的二次开发07】草图编辑器对象结构及应用
【CATIA的二次开发07】草图编辑器对象结构及应用 草图编辑器(SketchEditor)是用于创建和编辑2D草图的核心对象。其对象结构遵循CATIA的层级关系,以下是详细说明及代码示例: 一、核心对象结构图 Application │ └─ Documents│└─ Document (.CATPart)│└─ Part│└─…...

IT | 词汇科普手册Ⅱ
目录 1.报文(Message) 2.Token(令牌) Token vs. Cookie Token vs. Key "碰一碰"支付 3.NFC 4.Nginx 5.JSON 6.前置机 前置机vs.Nginx反向代理 以PDA、WMS举例前置机场景 7.RabbitMQ 核心功能 1.报文(Message) 报文(Message)是系统或组件之…...

【 java 基础问题 第一篇 】
目录 1.概念 1.1.java的特定有哪些? 1.2.java有哪些优势哪些劣势? 1.3.java为什么可以跨平台? 1.4JVM,JDK,JRE它们有什么区别? 1.5.编译型语言与解释型语言的区别? 2.数据类型 2.1.long与int类型可以互转吗&…...
以前端的角度理解 Kubernetes(K8s)
作为一名前端开发者,我们每天都在与 React、Vue、Webpack 等工具打交道,而 Kubernetes(K8s)听起来更像是后端或运维的“专属领域”。但实际上,K8s 的核心思想和前端开发中的某些模式高度相似。那么咱们用熟悉的类比帮助…...

自用git记录
像重复做自己在网上找的练习题,这种类型的git仓库管理,一般会用到以下命令: git revert a1b2c3 很复杂的git历史变成简单git历史 能用git rebase -i HEAD~5^这种命令解决,就最好(IDEA还带GUI,很方便&…...
pyhton基础【2】基本语法
一. 注释 单行注释 以#开头,#右边的所有的内容当做说明,起辅助说明作用 # 我是一个单行注释 print(Hello) 多行注释 """ 在三引号中的注释被称之为多行注释 可以写很多行的功能说明 """ 二. 交互模式 终端输入代码…...
python数据结构-列表详解
Python中的列表(List)是一种序列类型的数据结构,它支持元素的动态添加和删除,可以容纳任意类型的数据,包括数字、字符串、甚至是其他列表或其他复杂数据结构。列表因其灵活性和广泛的应用场景,成为Python中最常用的数据结构之一。…...

本地环境下 前端突然端口占用问题 针对vscode
1.问题背景 本地运行前端代码,虚拟机中使用nginx反向代理。两者都使用vscode进行开发。后端使用vscode远程连接。在前端发起一次接口请求后,后端会产生新的监听端口,出现如下图的提示情况。随后前端刷新,甚至无法正常显示界面。 …...
flutter 项目调试、flutter run --debug调试模式 devtools界面说明
Flutter DevTools 网页界面说明 1. 顶部导航栏 Inspector:查看和调试 Widget 树,实时定位 UI 问题。Performance-- 性能分析面板,查看帧率、CPU 和 GPU 使用情况,识别卡顿和性能瓶颈。Memory-- 内存使用和对象分配分析ÿ…...
在局域网(LAN)中查看设备的 IP 地址
在局域网(LAN)中查看设备的 IP 地址,可以使用以下几种方法: 方法 1:使用 ipconfig(Windows) 1. 打开 CMD: 按 Win R,输入 cmd,回车。 2. 输入命令&#…...
Axure 基本用法学习笔记
一、元件操作基础 1. 可见性控制 隐藏/显示:可以设置元件的可见性,使元件在特定条件下隐藏或可见 应用场景:创建动态交互效果,如点击按钮显示隐藏内容 2. 层级管理 层级概念:元件有上下层关系,上层元件…...
使用 Hyperlane 实现 WebSocket广播
使用 Hyperlane 实现 WebSocket广播 hyperlane 框架原生支持 WebSocket 协议,开发者无需关心协议升级过程,即可通过统一接口处理 WebSocket 请求。本文将介绍如何使用 hyperlane 实现服务端的单点发送与广播发送功能,以及如何配套实现一个简…...
SQL每日一题(5)
前言:五更!五更琉璃!不对!是,五更佩可! 原始数据: new_hires reasonother_column1other_column2校园招聘信息 11社会招聘信息 22内部推荐信息 33猎头推荐信息 44校园招聘信息 55社会招聘信息…...
git提交通用规范
提交类型 类型说明feat新增功能或特性fix修复Bugdocs文档更新(README、CHANGELOG、注释等)style代码样式调整(空格、分号、格式等,不改变逻辑)refactor代码重构(既非新增功能,也非修复Bug的代码…...

C++ - 仿 RabbitMQ 实现消息队列(3)(详解使用muduo库)
C - 仿 RabbitMQ 实现消息队列(3)(详解使用muduo库) muduo库的基层原理核心概念总结:通俗例子:餐厅模型优势体现典型场景 muduo库中的主要类EventloopMuduo 的 EventLoop 核心解析1. 核心机制:事…...

docker部署XTdrone
目录 一、前置准备 二、依赖安装 三、ros安装 四、gazebo安装 五、mavros安装 六、PX4的配置 七、Xtdrone源码下载 八、xtdrone与gazebo(实际上应该是第四步之后做这件事) 九、键盘控制 参考链接:仿真平台基础配置 语雀 一、前置准…...

图解 | 大模型智能体LLM Agents
文章目录 正文1. 存储 Memory1.1 短期记忆 Short-Term Memory1.1.1 模型的上下文窗口1.1.2 对话历史1.1.3 总结对话历史 1.2 长期记忆Long-term Memory 2. 工具Tools2.1 工具的类型2.2 function calling2.3 Toolformer2.3.1 大模型调研工具的过程2.3.2 生成工具调用数据集 2.4 …...
Lambda表达式的方法引用详解
Lambda表达式的方法引用详解 1. 方法引用的概念与作用 定义:方法引用(Method Reference)是Lambda表达式的一种简化写法,允许直接通过方法名引用已有的方法。核心目的:减少冗余代码,提升可读性,尤其在Lambda仅调用一个现有方法时。语法符号:双冒号 ::。2. 方法引用的四种…...

echarts设置标线和最大值最小值
echarts设置标线和最大值最小值 基本ECharts图表初始化配置 设置动态的y轴范围(min/max值) 通过markPoint标记最大值和最小值点 使用markLine添加水平参考线 配置双y轴图表 自定义标记点和线的样式(颜色、符号等) 响应式调整图表大…...
gcc编译构建流程
0. 项目结构 /home/pi/test/ ├── src/ │ ├── add/ │ │ ├── add.cpp │ │ ├── add.h │ └── log/ │ ├── log.cpp │ ├── log.h │ ├── data.h ├── main.cppmain.cpp代码 // main.cpp #include "log.h&quo…...

Maven 中央仓库操作指南
Maven 中央仓库操作指南 登录注册 在 Maven Central 登录(注册)账号。 添加命名空间 注册 通过右上角用户菜单跳转到命名空间管理页面: 注册命名空间: 填入你拥有的域名并注册: 刚提交的命名空间状态是Unverified…...

BUUCTF——RCE ME
BUUCTF——RCE ME 进入靶场 <?php error_reporting(0); if(isset($_GET[code])){$code$_GET[code];if(strlen($code)>40){die("This is too Long.");}if(preg_match("/[A-Za-z0-9]/",$code)){die("NO.");}eval($code); } else{highlight…...
clickhouse-1-特性及docker化安装
clickhouse-1-特性及docker化安装 1.核心特性1.1.列式存储与高效压缩1.2.向量化执行引擎1.3.分布式架构与高可用性1.4.多样化的表引擎1.5.实时处理能力2.安装2.1 拉取镜像2.2 创建容器3.连接4.使用4.1.创建数据库5.其他5.1 primary key5.2 ENG…...
Docker核心笔记
一、概述 1、架构 Docker容器基于镜像运行,容器共享宿主机的内核,不会加载额外内核,通过Namespaces(环境隔离)和Cgroups(资源控制)实现隔离,Cgroups会限容器使用资源并控制优先级和统计数据。隔离后的容器仅包含应用所需的用户态依赖 2、安装 安装先卸载再安装,使用的yum…...
log日志最佳实践
log日志最佳实践 1、占位符的使用2、延迟计算 1、占位符的使用 在进行日志打印的时候,推荐使用占位符进行字符串打印,而不是直接使用字符串拼接。原因: 这样可以避免不必要的字符串拼接。使用占位符时,实际字符串拼接由日志框架…...