华为OD机试真题——启动多任务排序(2025B卷:200分)Java/python/JavaScript/C/C++/GO最佳实现
2025 B卷 200分 题型
本专栏内全部题目均提供Java、python、JavaScript、C、C++、GO六种语言的最佳实现方式;
并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析;
本文收录于专栏:《2025华为OD真题目录+全流程解析+备考攻略+经验分享》
华为OD机试真题《启动多任务排序》:
文章快捷目录
题目描述及说明
Java
python
JavaScript
C++
C
GO
题目名称:启动多任务排序
- 知识点:拓扑排序(贪心策略)、字符串处理、逻辑分析
- 时间限制:1秒
- 空间限制:256MB
- 限定语言:不限
题目描述
一个应用启动时,会有多个初始化任务需要执行,且任务之间存在依赖关系。例如,任务A依赖任务B,则必须在B执行完成后才能开始执行A。现给出多条任务依赖规则,要求输出任务的执行顺序序列。规则采用贪婪策略:
- 若任务无依赖,则立即执行。
- 若多个任务可同时执行,按任务名称的字母顺序排序。
输入描述
- 输入参数为多个依赖关系,用空格分隔。
- 依赖关系格式为
X->Y
,表示任务X依赖任务Y(即Y需先于X执行)。 - 示例输入:
A->B C->B
输出描述
- 输出排序后的任务列表,用空格分隔。
- 示例输出:
B A C
示例说明
- 输入
A->B C->B
表示:- A依赖B,C依赖B → B无依赖,优先执行;A和C均依赖B,但按字母顺序输出A在前。
- 输出顺序为
B A C
。
Java
问题分析
我们需要解决任务的执行顺序问题,任务之间存在依赖关系,同时在多个任务可执行时按字母顺序选择。这属于典型的拓扑排序问题,但需要结合贪心策略选择字典序最小的任务。
解题思路
- 构建依赖图:将所有任务及其依赖关系转化为有向图,边表示依赖方向。
- 统计入度:记录每个任务的入度(前置依赖的数量)。
- 优先队列处理:使用优先队列存储当前可执行的任务(入度为0),按字母顺序取出任务。
- 拓扑排序:依次处理队列中的任务,减少其后继任务的入度,将新的可执行任务加入队列。
代码实现
import java.util.*;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);String input = scanner.nextLine();String[] dependencies = input.split(" ");Set<String> allNodes = new HashSet<>();Map<String, Set<String>> adj = new HashMap<>();Map<String, Integer> inDegree = new HashMap<>();for (String dep : dependencies) {if (dep.isEmpty()) continue;String[] parts = dep.split("->");if (parts.length != 2) continue;String x = parts[0];String y = parts[1];allNodes.add(x);allNodes.add(y);adj.computeIfAbsent(y, k -> new HashSet<>());if (adj.get(y).add(x)) { // 确保边不重复inDegree.put(x, inDegree.getOrDefault(x, 0) + 1);}}// 初始化入度:确保所有任务的入度被记录for (String node : allNodes) {inDegree.putIfAbsent(node, 0);}// 优先队列按字母顺序排序PriorityQueue<String> queue = new PriorityQueue<>();for (String node : inDegree.keySet()) {if (inDegree.get(node) == 0) {queue.offer(node);}}List<String> result = new ArrayList<>();while (!queue.isEmpty()) {String curr = queue.poll();result.add(curr);if (adj.containsKey(curr)) {for (String neighbor : adj.get(curr)) {inDegree.put(neighbor, inDegree.get(neighbor) - 1);if (inDegree.get(neighbor) == 0) {queue.offer(neighbor);}}}}System.out.println(String.join(" ", result));}
}
代码解析
- 读取输入:使用
Scanner
读取输入行,按空格分割得到多个依赖关系。 - 数据结构初始化:
allNodes
:收集所有任务节点。adj
:邻接表,记录每个节点的后续任务。inDegree
:记录每个任务的入度数。
- 处理依赖关系:
- 分割每个依赖关系为X->Y,将X和Y加入节点集合。
- 构建邻接表,添加边Y→X,确保边不重复,并更新X的入度。
- 初始化入度:确保每个节点的入度被正确记录,即使没有依赖。
- 优先队列初始化:将所有入度为0的任务加入队列,按字典序排序。
- 拓扑排序:依次处理队列中的任务,更新其后继任务的入度,将新的可执行任务加入队列。
- 输出结果:将拓扑排序结果按空格连接输出。
示例测试
示例1输入:
A->B C->B
输出:
B A C
解析:B无依赖先执行,A和C依赖B,按字母顺序执行A后C。
示例2输入:
B->A C->A D->B
输出:
A B D C
解析:A无依赖先执行,B依赖A,执行B后D依赖B,最后执行C。
示例3输入:
X->Y Y->Z
输出:
Z Y X
解析:Z无依赖先执行,Y依赖Z,之后X依赖Y。
综合分析
- 时间复杂度:拓扑排序的时间复杂度为O(N + E),其中N为任务数,E为边数。优先队列的插入和取出操作为O(log N),整体复杂度O(N log N + E)。
- 空间复杂度:存储邻接表和入度表的空间复杂度为O(N + E)。
- 正确性:贪心选择字典序最小的任务保证了题目要求的顺序,拓扑排序确保依赖关系正确。
- 适用性:适用于任务调度、编译顺序等需要依赖管理的场景,高效处理数千级别的节点和边。
python
问题分析
我们需要根据任务的依赖关系确定执行顺序,多个可执行任务时按字母顺序选择。这可以通过拓扑排序结合贪心策略实现,使用优先队列处理当前可执行任务。
解题思路
- 构建依赖图:将每个任务的依赖关系转化为有向边,记录每个任务的入度(前置依赖的数量)。
- 优先队列初始化:将入度为0的任务按字母顺序加入优先队列。
- 拓扑排序:依次执行队列中的任务,减少其后继任务的入度,将新可执行任务加入队列。
- 处理顺序:按字母顺序选择任务,确保符合题目要求。
代码实现
import sys
import heapq
from collections import defaultdictdef main():input_str = sys.stdin.read().strip()dependencies = input_str.split()adj = defaultdict(list)in_degree = defaultdict(int)all_nodes = set()for dep in dependencies:if '->' not in dep:continuex, y = dep.split('->')all_nodes.add(x)all_nodes.add(y)adj[y]
相关文章:

华为OD机试真题——启动多任务排序(2025B卷:200分)Java/python/JavaScript/C/C++/GO最佳实现
2025 B卷 200分 题型 本专栏内全部题目均提供Java、python、JavaScript、C、C++、GO六种语言的最佳实现方式; 并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析; 本文收录于专栏:《2025华为OD真题目录+全流程解析+备考攻略+经验分…...
AWS云与第三方通信最佳实践:安全、高效的数据交互方案
引言 在当今的云计算时代,企业经常需要在AWS云环境中存储和处理数据,同时还需要与第三方应用或服务进行数据交互。如何安全、高效地实现这种通信是许多企业面临的挑战。本文将详细探讨几种AWS云与第三方通信的方案,并分析它们的优缺点,帮助您为自己的业务场景选择最佳解决…...
Ubuntu Server 24 设置 WiFi 网络的方案
一、配置流程 1. 确认无线网卡信息 首先需明确无线网卡接口名称及当前连接状态: ip link show # 查看网络接口(寻找状态为 "UP" 的无线接口,如 wlan0、wlx* 或 wlp1s0) iwconfig # 确认无线网…...
【redis】redis和hiredis的基本使用
总结: 介绍了一下redis和hiredis的安装步骤,用一个简单的demo演示了使用redis的基本过程。 启动redis步骤 1、下载redis:https://github.com/redis/redis 2、编译命令:make 3、编译产物:libredis.a(静…...

大模型时代,Python 近红外光谱与 Transformer 模型:学习的必要性探究
在当下大语言模型盛行的时代,各类新技术如潮水般不断涌现,让人应接不暇。身处这样的浪潮之中,不少人心中都会泛起疑问:Python 近红外光谱和 Transformer 模型还有学习的必要性吗?今天,就让我们深入探讨一番…...
产品经理常用术语大全
作为一名产品经理,不仅需要具备跨领域的知识和技能,还需要熟练掌握一系列专业术语,以便更有效地沟通、规划和执行产品开发过程中的各项任务。以下是一篇详细介绍产品经理日常工作中常见术语的文章,旨在帮助新手快速入门࿰…...

梯度优化提示词:精准引导AI分类
基于梯度优化的提示词工程方法,通过迭代调整提示词的嵌入向量,使其能够更有效地引导模型做出正确分类。 数据形式 训练数据 train_data 是一个列表,每个元素是一个字典,包含两个键: text: 需要分类的文本描述label: 对应的标签(“冲动"或"理性”)示例数据: …...

AUTOSAR 运行时环境 (RTE)
目录 往期推荐 什么是运行时环境? AUTOSAR 中的运行时环境 (RTE) RTE 的应用 RTE 的生成 关于RTE API的一些信息 RTE生成后文件之间的关系 往期推荐 2025汽车行业新宠:欧企都在用的工具软件ETAS工具链自动化实战指南<一>ET…...
Bolt.new:重塑 Web 开发格局的 AI 利器
根据 Menlo Ventures 2024 年的调查,在主流 AI 应用场景中,AI 编程工具的采用率以 51% 位居榜首,代码生成成为最易落地且受欢迎的场景。科技巨头谷歌 CEO Sundar Pichai 在 2024 年 10 月财报会议上透露,公司超四分之一的新代码由…...
RK3588 RKNN ResNet50推理测试
RK3588 RKNN ResNet50推理测试 一、背景二、性能数据三、操作步骤3.1 安装依赖3.2 安装rknn-toolkit,更新librknnrt.so3.3 下载推理图片3.4 生成`onnx`模型转换脚本3.5 生成rknn模型3.6 运行rknn模型一、背景 在嵌入式设备上进行AI推理时,我们面临着算力有限、功耗敏感等挑战…...

SQLMesh 宏操作符详解:提升 SQL 查询的灵活性与效率
SQLMesh 提供了一系列强大的宏操作符(如 WITH、JOIN、WHERE 等),用于动态构建 SQL 查询。这些操作符不仅简化了复杂查询的编写,还提高了代码的可读性和可维护性。本文将深入探讨这些操作符的使用场景、语法及实际案例,…...
leetcode513.找树左下角的值:递归深度优先搜索中的最左节点追踪之道
一、题目本质与核心诉求解析 在二叉树算法问题中,"找树左下角的值"是一个典型的结合深度与位置判断的问题。题目要求我们找到二叉树中最深层最左边的节点值,这里的"左下角"有两个关键限定: 深度优先:必须是…...

基于Flink的数据中台管理平台
基于Flink做的数据中台工程项目。数据从source到clickhouse全流程的验证。集成元数据管、数据资产、数据发现功能,自主管理元数据变更,集成元数据版本管理。 同时,对整个大数据集群使用到的组件或者是工具进行管理。比如nacos、kafka、zookee…...

AI-Ready TapData:如何基于 MCP 协构建企业级 AI 实时数据中枢?(含教程)
随着企业对私有大模型、行业大模型的探索逐渐深入,“AI应用是否真正落地”,越来越取决于企业是否拥有结构化、实时、可交互的高质量数据。而现实是,大多数企业的核心业务数据依旧被困在多个异构系统、孤岛数据库和 ETL 流程之中,导…...

Spring Boot 登录实现:JWT 与 Session 全面对比与实战讲解
Spring Boot 登录实现:JWT 与 Session 全面对比与实战讲解 2025.5.21-23:11今天在学习黑马点评时突然发现用的是与苍穹外卖jwt不一样的登录方式-Session,于是就想记录一下这两种方式有什么不同 在实际开发中,登录认证是后端最基础也是最重要…...
【HTML-5】HTML 实体:完整指南与最佳实践
1. 什么是 HTML 实体? HTML 实体是一种在 HTML 文档中表示特殊字符的方法,这些字符如果直接使用可能会与 HTML 标记混淆,或者无法通过键盘直接输入。实体由 & 符号开始,以 ; 分号结束。 <p>这是一个小于符号的实体&am…...

SpringBoot 项目实现操作日志的记录(使用 AOP 注解模式)
本文是博主在做关于如何记录用户操作日志时做的记录,常见的项目中难免存在一些需要记录重要日志的部分,例如权限和角色设定,重要数据的操作等部分。 博主使用 Spring 中的 AOP 功能,结合注解的方式,对用户操作过的一些…...

AI|Java开发 IntelliJ IDEA中接入本地部署的deepseek方法
目录 连接本地部署的deepseek: IntelliJ IDEA中使用deepseek等AI: 用法一:让AI写代码 用法二:选中这段代码,右键,可以让其解释这段代码的含义。这时显示的解释是英文的。 连接本地部署的deepseek&#…...
【疑难杂症】Vue前端下载文件无法打开 已解决
由于刚学了VUE不久,不清楚底层逻辑。我遇到从后台下载文件无法打开的问题。 测试下来是,请求时未设置 responseType: blob。 axios 默认的 responseType 是 json ,会尝试将响应体解析为JSON。但文件下载场景需要后端返回二进制流࿰…...

【1——Android端添加隐私协议(unity)1/3】
前言:这篇仅对于unity 发布Android端上架国内应用商店添加隐私协议,隐私协议是很重要的东西,没有这个东西,是不上了应用商店的。 对于仅仅添加隐私协议,我知道有三种方式,第一种和第二种基本一样 1.直接在unity里面新…...

Linux之概述和安装vm虚拟机
文章目录 操作系统概述硬件和软件操作系统常见操作系统 初识LinuxLinux的诞生Linux内核Linux发行版 虚拟机介绍虚拟机 VMware WorkStation安装虚拟化软件VMware WorkStation 安装查看VM网络连接设置VM存储位置 在VMware上安装Linux(发行版CentOS7)安装包获取CentOS7 安装 Mac系…...
深入理解 Linux 的 set、env 和 printenv 命令
在 Linux 和类 Unix 系统中,环境变量是配置和管理 Shell 及进程行为的核心机制。set、env 和 printenv 是与环境变量交互的三个重要命令,每个命令都有其独特的功能和用途。本文将详细探讨这三个命令的区别,帮助大家更好地理解和使用这些命令。…...

LeetCode热题100--19.删除链表的倒数第N个结点--中等
1. 题目 给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。 示例 1: 输入:head [1,2,3,4,5], n 2 输出:[1,2,3,5] 示例 2: 输入:head [1], n 1 输出:[] 示例…...
开发AR导航助手:ARKit+Unity+Mapbox全流程实战教程
引言 在增强现实技术飞速发展的今天,AR导航应用正逐步改变人们的出行方式。本文将手把手教你使用UnityARKitMapbox开发跨平台AR导航助手,实现从虚拟路径叠加到空间感知的完整技术闭环。通过本教程,你将掌握: AR空间映射与场景理…...

git学习与使用(远程仓库、分支、工作流)
文章目录 前言简介git的工作流程git的安装配置git环境:git config --globalgit的基本使用新建目录初始化仓库(repository)添加到暂存区新增/修改/删除 文件状态会改变 提交到仓库查看提交(commit)的历史记录git其他命令…...
嵌入式预处理链接脚本lds和map文件
在嵌入式开发中,.lds.S 文件是一个 预处理后的链接脚本(Linker Script),它结合了 C 预处理器(Preprocessor) 的功能和链接脚本的语法。它的核心作用仍然是 定义内存布局和链接规则,但通过预处理…...
9. Spring AI 各版本的详细功能与发布时间整理
目录 一、旧版本(Legacy) 0.8.1(2024年3月) 二、里程碑版本(Milestone) 1.0.0-M1(2024年5月30日) 1.0.0-M2(2024年7月) 1.0.0-M3(2024年10月8日) 1.0.0-M4(2024年12月) 1.0.0-M5(2025年1月9日) 1.0.0-M6(2025年3月) 1.0.0-M7(2025年4月14日) 1.…...

《Android 应用开发基础教程》——第十四章:Android 多线程编程与异步任务机制(Handler、AsyncTask、线程池等)
目录 第十四章:Android 多线程编程与异步任务机制(Handler、AsyncTask、线程池等) 🔸 14.1 为什么需要多线程? 🔸 14.2 Handler Thread 模型 ✦ 使用 Handler 与 Thread 进行线程通信 ✦ 简要说明&am…...
Apache 高级配置实战:从连接保持到日志分析的完整指南
Apache 高级配置实战:从连接保持到日志分析的完整指南 前言 最近在深入学习 Apache 服务器配置时,发现很多朋友对 Apache 的高级功能还不够了解。作为一个在运维路上摸爬滚打的技术人,我想把这些实用的配置技巧分享给大家。今天这篇文章会带…...
开源 OIDC(OpenID Connect)身份提供方(IdP)、iam选型
文章目录 开源 OIDC(OpenID Connect)身份提供方(IdP)、iam选型主流开源 OIDC(OpenID Connect)身份提供方(IdP)zitadeldexory开源 OIDC(OpenID Connect)身份提供方(IdP)、iam选型 主流开源 OIDC(OpenID Connect)身份提供方(IdP) 当前主流的**开源 OIDC(OpenI…...