当前位置: 首页 > article >正文

华为OD机试真题 新系统 2026-05-06 JavaGoC语言 实现【匹配命令行前缀关键字】

目录题目思路Code题目给定一组命令行字符串和一个命令前缀需要找出所有以前缀开头的命令行表达式中前缀之后的第一个关键字并将这些关键字按字典序排序后返回。如果找不到匹配前缀则返回空匹配出多个相同关键字时只返回一个。完整示例示例1给定命令行表达式 [display device,display port status]输入前缀是 display则返回 [device,port]。示例2给定命令行表达式 [set negotiation mode,set port down]输入前缀是 则返回 [set]。示例3给定命令行表达式 [git commit -m message,git push origin master,git pull]输入前缀是 git则返回 [commit,pull,push]。补充说明命令行条数 0~1000每个命令行长度为 [1,200]每个命令行表达式中的关键字由小写字母、- 组成命令行关键字不包含空格关键字之间用空格分隔只有关键字之间的空格有意义字符串首尾空格需要忽略如 a 等价于 a a b 等价于 a b输入描述第一行输入前缀从第二行到结束每行输入一个命令行输出描述找出所有以前缀开头的命令行表达式中前缀之后的第一个关键字并按字典序排序后输出以空格分割样例1输入displaydisplay port statusdisplay device输出device port说明每个命令行都和前缀 display 匹配返回每个命令的第二个关键字。样例2输入set negotiation modeset port down输出set说明首先匹配 的命令关键字为 2 个 set去重后返回 1 个 set。思路字符串模拟操作类型的题目较为简单。先把前缀和每条命令都按空白字符拆成关键字数组。如果命令的前若干个关键字和前缀关键字完全一致就说明匹配成功。此时取“前缀之后的第一个关键字”加入集合去重最后将集合排序并用空格拼接输出。关键点有两个要先 strip split这样才能正确处理题目说的“首尾空格无意义”如果前缀刚好等于整条命令没有“后一个关键字”这种情况不能加入结果Codeimport java.io.BufferedReader; import java.io.InputStreamReader; import java.util.*; public class Main { static ListString normalize(String command) { command command.trim(); if (command.isEmpty()) { return new ArrayList(); } // 按一个或多个空白字符切分兼容多空格情况。 return Arrays.asList(command.split(\\s)); } public static void main(String[] args) throws Exception { BufferedReader br new BufferedReader(new InputStreamReader(System.in)); ListString lines new ArrayList(); String line; // 保留第一行前缀其余行作为命令输入。 while ((line br.readLine()) ! null) { lines.add(line); } if (lines.isEmpty()) { return; } ListString prefixTokens normalize(lines.get(0)); SetString result new TreeSet(); for (int i 1; i lines.size(); i) { ListString commandTokens normalize(lines.get(i)); // 空命令行不产生结果。 if (commandTokens.isEmpty()) { continue; } // 如果前缀比命令还长不可能匹配。 if (prefixTokens.size() commandTokens.size()) { continue; } boolean match true; // 逐个关键字判断前缀是否匹配。 for (int j 0; j prefixTokens.size(); j) { if (!prefixTokens.get(j).equals(commandTokens.get(j))) { match false; break; } } if (!match) { continue; } // 前缀之后必须还有一个关键字才加入答案。 if (commandTokens.size() prefixTokens.size()) { result.add(commandTokens.get(prefixTokens.size())); } } System.out.print(String.join( , result)); } }C#include stdio.h #include string.h #include stdlib.h #define MAX_LINES 1005 #define MAX_LEN 205 #define MAX_TOKENS 205 void normalize(const char *command, char tokens[][MAX_LEN], int *count) { char buffer[MAX_LEN]; strcpy(buffer, command); *count 0; char *token strtok(buffer, \t\r\n); while (token ! NULL) { strcpy(tokens[*count], token); (*count); token strtok(NULL, \t\r\n); } } int main() { char lines[MAX_LINES][MAX_LEN]; int lineCount 0; while (fgets(lines[lineCount], sizeof(lines[lineCount]), stdin)) { lines[lineCount][strcspn(lines[lineCount], \r\n)] \0; lineCount; } if (lineCount 0) { return 0; } char prefixTokens[MAX_TOKENS][MAX_LEN]; int prefixCount 0; normalize(lines[0], prefixTokens, prefixCount); char result[MAX_TOKENS][MAX_LEN]; int resultCount 0; for (int i 1; i lineCount; i) { char commandTokens[MAX_TOKENS][MAX_LEN]; int commandCount 0; normalize(lines[i], commandTokens, commandCount); // 空命令行跳过。 if (commandCount 0) { continue; } if (prefixCount commandCount) { continue; } int match 1; for (int j 0; j prefixCount; j) { if (strcmp(prefixTokens[j], commandTokens[j]) ! 0) { match 0; break; } } if (!match) { continue; } if (commandCount prefixCount) { char *candidate commandTokens[prefixCount]; // 手动去重。 int exists 0; for (int k 0; k resultCount; k) { if (strcmp(result[k], candidate) 0) { exists 1; break; } } if (!exists) { strcpy(result[resultCount], candidate); } } } // 简单字典序排序。 for (int i 0; i resultCount; i) { for (int j i 1; j resultCount; j) { if (strcmp(result[i], result[j]) 0) { char tmp[MAX_LEN]; strcpy(tmp, result[i]); strcpy(result[i], result[j]); strcpy(result[j], tmp); } } } for (int i 0; i resultCount; i) { if (i 0) { printf( ); } printf(%s, result[i]); } return 0; }GOpackage main import ( bufio fmt os sort strings ) func normalize(command string) []string { // strings.Fields 会自动忽略首尾空格并按连续空白切分。 return strings.Fields(command) } func main() { scanner : bufio.NewScanner(os.Stdin) lines : make([]string, 0) for scanner.Scan() { lines append(lines, scanner.Text()) } if len(lines) 0 { return } prefixTokens : normalize(lines[0]) resultSet : make(map[string]bool) for i : 1; i len(lines); i { commandTokens : normalize(lines[i]) // 空命令行不会贡献关键字。 if len(commandTokens) 0 { continue } if len(prefixTokens) len(commandTokens) { continue } match : true for j : 0; j len(prefixTokens); j { if prefixTokens[j] ! commandTokens[j] { match false break } } if !match { continue } if len(commandTokens) len(prefixTokens) { resultSet[commandTokens[len(prefixTokens)]] true } } result : make([]string, 0, len(resultSet)) for word : range resultSet { result append(result, word) } sort.Strings(result) fmt.Print(strings.Join(result, )) }【华为od机试真题PythonJSJavaGo合集】【超值优惠】Py/JS/Java/Go合集【华为od机试真题Python】Python真题题库【华为od机试真题JavaScript】JavaScript真题题库【华为od机试真题JavaGo】JavaGo真题题库【华为od机试真题C】C真题题库【华为od机试真题C语言】C语言真题题库【华为od面试手撕代码题库】面试手撕代码题库【华为od机试面试交流群】【文章底部有二维码链接可扫码加交流群】华为OD机试:二本院校有机会吗?有机会,但不大,大神除外!机考分数越高越好,所以需要提前刷题。机考通过后,如果没有收到面试邀请,也不要着急,非目标院校面试邀请发的时间比较晚。非目标院校今年有点难,机试至少要考到350分,所以需要疯狂刷题,华为OD机考是有题库的,最好在考前完所有题库题目。华为OD机试:跨专业可以参加华为OD可以,但是如果你的本科院校比较差,上岸概率不大。华为OD机试:华为OD简历被锁定机试通过,性格测试也通过,但是没人联系面试,发现简历被锁定。此时需要主动去联系HR。让他帮助你查询原因。

相关文章:

华为OD机试真题 新系统 2026-05-06 JavaGoC语言 实现【匹配命令行前缀关键字】

目录 题目 思路 Code 题目 给定一组命令行字符串和一个命令前缀,需要找出所有以前缀开头的命令行表达式中,前缀之后的第一个关键字,并将这些关键字按字典序排序后返回。 如果找不到匹配前缀则返回空;匹配出多个相同关键字时只返…...

从‘Hello World’到打开PRT文件:一个完整的NX C++外部exe开发入门实战(VS2015 + NX12)

从‘Hello World’到打开PRT文件:一个完整的NX C外部exe开发入门实战(VS2015 NX12) 在工业设计领域,NX(原Unigraphics)作为一款功能强大的CAD/CAM/CAE软件,其二次开发能力为工程师提供了极大的…...

别再硬改CSS了!ElementUI el-table透明背景的3种正确姿势(含Vue2/Vue3避坑指南)

别再硬改CSS了!ElementUI el-table透明背景的3种正确姿势(含Vue2/Vue3避坑指南) 在深色主题或背景融合的现代Web应用中,ElementUI的el-table组件默认的白色背景常常成为视觉设计的绊脚石。许多开发者第一反应是直接修改CSS文件&am…...

VSCode界面突然变英文了?别慌,一分钟教你切回中文(附快捷键和常见问题解决)

VSCode界面突然变英文了?别慌,一分钟教你切回中文(附快捷键和常见问题解决) 早上打开VSCode准备写代码,突然发现所有菜单和按钮都变成了英文?这种突如其来的"国际化"体验确实让人措手不及。别担…...

告别IDEA编译警告:深入解析JDK版本过时问题与多维度解决方案

1. 当IDEA开始"抱怨":那些烦人的编译警告从哪来? 每次打开老项目,总能看到那个熟悉的黄色警告:"Warning:java: 源值1.5已过时,将在未来所有发行版中删除"。这个提示就像个唠叨的老朋友&#xff0c…...

告别龟速下载!用阿里云Maven仓库和离线驱动包,5分钟搞定DBeaver所有JDBC驱动配置

极速配置DBeaver JDBC驱动的双轨方案:阿里云Maven加速与离线整合包实战 每次打开DBeaver准备连接数据库时,看着进度条缓慢爬升的驱动下载界面,你是否也感到焦虑?特别是在紧急排查生产环境问题的关键时刻,这种等待简直让…...

IDEA 2023.2 版本中,如何一键开启Services面板管理你的Spring Boot微服务集群?

IDEA 2023.2 版本中如何高效管理Spring Boot微服务集群 微服务架构的流行让开发者面临一个现实挑战:如何在本地开发环境中高效管理多个同时运行的Spring Boot服务。传统方式需要逐个启动、切换终端查看日志,既浪费时间又容易造成混乱。JetBrains IDEA作为…...

ElementUI Transfer穿梭框数据回填全攻略:编辑时如何优雅地还原选中状态?

ElementUI Transfer穿梭框数据回填实战:编辑场景下的状态还原艺术 在后台管理系统开发中,权限配置、内容关联等场景频繁使用穿梭框组件。ElementUI的Transfer组件凭借直观的双栏设计和丰富的API,成为这类需求的首选解决方案。但许多开发者在编…...

3PEAK思瑞浦 TP2262-SR SOP8 运算放大器

特性 供电电压:3V至36V 低供电电流:每通道700uA 轨到轨输出 带宽:4MHz 斜率:15V/us 优异的EMI抑制性能 偏移电压:最大3毫伏 偏移电压温度漂移:2V/C 低噪声:1kHz时30nV/vHz 工作温度范围:-40C至125C...

Arduino Uno R3 bootloader烧写避坑全记录:从USBasp驱动安装到熔丝位设置(Win10/11实测)

Arduino Uno R3 bootloader烧写实战指南:从驱动配置到熔丝位安全操作 当一块全新的Atmega328P芯片静静躺在工作台上时,它就像一张白纸,等待着被赋予生命。作为硬件开发者,我们常常需要为这些空白芯片注入灵魂——烧写bootloader。…...

SITS 2026多目标优化落地指南:从梯度冲突到任务解耦,7步实现Pareto前沿精度提升23.6%

更多请点击: https://intelliparadigm.com 第一章:AI原生多任务学习:SITS 2026多目标优化实战技巧 在SITS 2026竞赛框架下,AI原生多任务学习(AI-Native Multi-Task Learning, AMTL)不再依赖传统单任务迁移…...

从零构建开源任务管理中枢:TaskWing部署、插件化与自动化实战

1. 项目概述:从零到一,打造你的个人任务管理中枢如果你和我一样,每天被各种待办事项、项目进度、临时想法和会议记录搞得焦头烂额,那么你肯定不止一次地想过:有没有一个工具,能真正“懂”我,能把…...

3PEAK思瑞浦 TP2262-TSR TSSOP8 运算放大器

特性 供电电压:3V至36V 低供电电流:每通道最大1000A差分输入电压范围至电源轨,可作为比较器工作 输入轨至-Vs,轨到轨输出快速响应:3.5MHz带宽,15V/us斜率,100ns过载恢复时间 低失调电压:-25C时最大2mV-2.5 mV在-40C至85C(最大) -3…...

3步掌握League Akari:高效智能的英雄联盟本地自动化工具

3步掌握League Akari:高效智能的英雄联盟本地自动化工具 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power 🚀. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit League Akari是一款基于英…...

从Awesome List到实战:构建你的AI编程工作流与Vibe Coding环境

1. 从“Awesome List”到“Vibe Coding”实战指南:如何构建你的AI编程工作流如果你最近在GitHub上逛过,或者关注AI编程工具的圈子,大概率会刷到一个叫“Awesome Vibe Coding”的仓库。乍一看,它像是一个又一个AI工具和项目的简单罗…...

Perplexity Stack Overflow查询响应延迟超8秒?紧急修复指南:从token压缩到领域微调的4层加速方案

更多请点击: https://intelliparadigm.com 第一章:Perplexity Stack Overflow查询响应延迟超8秒?紧急修复指南:从token压缩到领域微调的4层加速方案 当Perplexity在Stack Overflow数据源上出现平均响应延迟 > 8s 的告警时&am…...

5大优化技巧:让ComfyUI-Manager在低配置设备上流畅运行

5大优化技巧:让ComfyUI-Manager在低配置设备上流畅运行 【免费下载链接】ComfyUI-Manager ComfyUI-Manager is an extension designed to enhance the usability of ComfyUI. It offers management functions to install, remove, disable, and enable various cust…...

从玩具到生产:基于run-llama/rags构建模块化RAG系统的工程实践

1. 项目概述:从“玩具”到“生产力”的RAG系统构建如果你最近在关注大语言模型的应用落地,那么“RAG”这个词一定高频出现在你的视野里。RAG,即检索增强生成,它试图解决大模型“一本正经胡说八道”和“知识陈旧”两大核心痛点。简…...

Zotero茉莉花插件:3大功能轻松管理中文文献,科研效率翻倍提升

Zotero茉莉花插件:3大功能轻松管理中文文献,科研效率翻倍提升 【免费下载链接】jasminum A Zotero add-on to retrive CNKI meta data. 一个简单的Zotero 插件,用于识别中文元数据 项目地址: https://gitcode.com/gh_mirrors/ja/jasminum …...

【源码深度】Android 系统底层机制精讲|Linux 进程 Binder 通信 ART 虚拟机|Android 全栈体系 150 讲 - 41

...

基于MCP的AI智能体:自动化与优化亚马逊DSP广告实战指南

1. 项目概述:用AI智能体管理亚马逊DSP广告如果你正在寻找一种更高效、更智能的方式来管理亚马逊需求方平台(Amazon DSP)的广告活动,那么这个项目可能就是为你准备的。作为一个在程序化广告领域摸爬滚打了十多年的从业者&#xff0…...

SubLens:AI订阅管理浏览器插件,一站式聚合账单与扣款提醒

1. 项目概述:一个帮你管好AI订阅账单的浏览器插件 如果你和我一样,订阅了不止一个AI服务——比如ChatGPT Plus用来日常对话和写作,Claude Pro用来处理长文档,GitHub Copilot写代码,Cursor辅助开发,再加上G…...

XClaw Skill:AI Agent的社交网络与技能市场接入实战指南

1. 项目概述:XClaw Skill,AI Agent的“社交网络”与“技能市场”通行证如果你正在开发或使用AI Agent,并且希望它不再是一个信息孤岛,而是能与其他Agent交流、协作、甚至通过自己的“手艺”赚取收益,那么XClaw.network…...

技术债务的职场政治:谁该为历史遗留问题买单

在软件测试从业者的日常工作中,技术债务是一个绕不开的话题。它像一颗隐藏在代码深处的定时炸弹,随时可能在项目推进的某个节点爆发,引发一系列连锁反应。而当技术债务问题浮出水面时,一场关于“谁该为历史遗留问题买单”的职场政…...

轻量级GraphRAG框架nano-graphrag:模块化设计与实践指南

1. 项目概述:一个为开发者而生的轻量级GraphRAG实现 如果你正在寻找一个能够快速上手、代码清晰、易于二次开发的GraphRAG(图增强检索生成)框架,那么 nano-graphrag 很可能就是你需要的那个工具。GraphRAG这个概念,简…...

开源数字白板the-board:基于React+Fabric.js的实时协作技术解析

1. 项目概述:一个开源的“数字白板”能做什么?最近在GitHub上看到一个挺有意思的项目,叫the-board。乍一看名字,可能觉得平平无奇,但点进去你会发现,它其实是一个功能相当完整的在线白板应用。简单来说&…...

我们给大模型接上了CI/CD流水线,测试通过率从60%飙升到95%

在软件测试领域,质量保障体系的进化从未停歇。当大语言模型(LLM)从实验性项目走向生产环境,测试团队面临一个尖锐的矛盾:模型迭代速度以天甚至小时计,而传统的人工评估与回归测试却需要数周。我们团队在将大…...

Arm嵌入式多线程编程:原理、实践与优化

1. Arm嵌入式开发中的多线程编程基础在嵌入式系统开发中,多线程编程是提高系统响应能力和资源利用率的重要手段。Arm架构作为嵌入式领域的主流处理器架构,其编译器工具链对多线程编程提供了完善的支持。不同于通用计算环境,嵌入式系统的多线程…...

i.MX 6UL/6ULL开发环境配置与驱动开发实战

1. i.MX 6UL/6ULL开发环境配置实战1.1 虚拟机环境搭建要点对于Windows平台下的i.MX开发,VirtualBox虚拟机是最经济实惠的选择。根据实际项目经验,建议配置如下:内存至少4GB(复杂项目推荐8GB)硬盘空间预留100GB&#xf…...

InjectFix实战解析:在Unity IL2CPP环境下实现C#热修复的权衡与策略

1. InjectFix在IL2CPP环境下的核心价值 当你的Unity手游在应用商店上线后突然出现致命Bug,传统解决方案往往需要重新打包、提交审核、等待上架,这个过程可能耗时数天。而InjectFix提供的C#热修复能力,可以在不更新客户端的情况下快速修复线上…...