news 2026/5/7 18:25:01

华为OD机试真题 - 查字典 (C++ Python JAVA JS GO)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
华为OD机试真题 - 查字典 (C++ Python JAVA JS GO)

查字典

2025华为OD机试双机位C卷 - 华为OD上机考试双机位C卷 100分题型

华为OD机试双机位C卷真题目录点击查看: 华为OD机试双机位C卷真题题库目录|机考题库 + 算法考点详解

题目描述

输入一个单词前缀和一个字典,输出包含该前缀的单词

输入描述

单词前缀+字典长度+字典
字典是一个有序单词数组
输入输出都是小写

输出描述

所有包含该前缀的单词,多个单词换行输出

若没有则返回-1

用例1

输入

b 3 a b c

输出

b

用例2

输入

abc 4 a ab abc abcd

输出

abc abcd

用例3

输入

a 3 b c d

输出

-1

题解

思路:模拟

  1. 这道题比较简单,之间判断词典中所有单词是有以prefix开头即可。
  2. 考虑到这道题没有限制单词的数量,如果全部存在数组中可能会超内存,可以判断一个单词以prefix开头就直接输出。至于-1的情况可以使用一个布尔值进行记录。
  3. 具体逻辑看看下面代码就ok。

c++

#include<iostream> #include<vector> #include<string> #include <utility> #include <sstream> #include<algorithm> #include<cmath> #include<map> using namespace std; int main() { string prefix; int n; cin >> prefix; cin >> n; // 标记是否找到 bool flag = false; int prefixLen = prefix.size(); for (int i = 0; i < n; i++) { string input; cin >> input; // 判断是否为前缀 if (prefix == input.substr(0, prefixLen)) { flag = true; cout << input << endl; } } // 没有找到情况下 if (!flag) { cout << -1; } return 0; }

JAVA

import java.util.*; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String prefix = sc.next(); int n = sc.nextInt(); // 标记是否找到 boolean flag = false; int prefixLen = prefix.length(); for (int i = 0; i < n; i++) { String input = sc.next(); // 判断是否为前缀 if (input.length() >= prefixLen && prefix.equals(input.substring(0, prefixLen))) { flag = true; System.out.println(input); } } // 没有找到情况下 if (!flag) { System.out.print(-1); } } }

Python

importsys data=sys.stdin.read().split()idx=0prefix=data[idx]idx+=1n=int(data[idx])idx+=1# 标记是否找到flag=Falseprefix_len=len(prefix)for_inrange(n):s=data[idx]idx+=1# 判断是否为前缀ifs.startswith(prefix):flag=Trueprint(s)# 没有找到情况下ifnotflag:print(-1)

JavaScript

constreadline=require('readline');// 创建 readline 接口constrl=readline.createInterface({input:process.stdin,output:process.stdout});consttokens=[];// 逐行读取输入rl.on('line',(line)=>{// 按空白切分,支持空格 / 多个空格tokens.push(...line.trim().split(/\s+/));});rl.on('close',()=>{letidx=0;// 读取前缀constprefix=tokens[idx++];// 读取数量constn=parseInt(tokens[idx++],10);// 标记是否找到letflag=false;constprefixLen=prefix.length;for(leti=0;i<n;i++){consts=tokens[idx++];// 判断是否为前缀if(s.startsWith(prefix)){flag=true;console.log(s);}}// 没有找到情况下if(!flag){console.log(-1);}});

Go

packagemainimport("bufio""fmt""os")funcmain(){in:=bufio.NewReader(os.Stdin)varprefixstringvarnintfmt.Fscan(in,&prefix,&n)// 标记是否找到flag:=falseprefixLen:=len(prefix)fori:=0;i<n;i++{varsstringfmt.Fscan(in,&s)// 判断是否为前缀iflen(s)>=prefixLen&&s[:prefixLen]==prefix{flag=truefmt.Println(s)}}// 没有找到情况下if!flag{fmt.Print(-1)}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/6 9:48:27

Open-AutoGLM沙箱机制深度解析:如何实现企业级隐私计算与安全隔离

第一章&#xff1a;Open-AutoGLM隐私隔离沙箱机制概述 Open-AutoGLM 是一款面向自动化生成式任务的开源框架&#xff0c;其核心设计之一是隐私隔离沙箱机制。该机制旨在确保在模型推理与数据处理过程中&#xff0c;用户敏感信息不被泄露或滥用。通过构建轻量级、可验证的运行环…

作者头像 李华
网站建设 2026/4/27 18:48:48

iperf3终极网络测速指南:免费跨平台带宽测试解决方案

iperf3终极网络测速指南&#xff1a;免费跨平台带宽测试解决方案 【免费下载链接】iperf3网络测试工具-Win64AndroidAPK iperf3 网络测试工具 - Win64 Android APK 项目地址: https://gitcode.com/open-source-toolkit/01598 iperf3作为专业的网络测速和带宽测试工具&a…

作者头像 李华
网站建设 2026/5/1 11:05:42

5大核心技术:深度解析EmotiVoice模型特征可视化分析方法

5大核心技术&#xff1a;深度解析EmotiVoice模型特征可视化分析方法 【免费下载链接】EmotiVoice EmotiVoice &#x1f60a;: a Multi-Voice and Prompt-Controlled TTS Engine 项目地址: https://gitcode.com/gh_mirrors/em/EmotiVoice EmotiVoice作为多语音和提示控制…

作者头像 李华
网站建设 2026/5/2 0:54:12

构建智能实时交互系统:LiveKit与本地化AI的深度集成实践

在远程协作、在线教育等场景中&#xff0c;传统音视频系统面临智能化程度不足、隐私泄露风险等核心痛点。本文通过LiveKit Agents框架与Ollama本地大语言模型的创新结合&#xff0c;提供了一套隐私保护与低延迟并重的实时AI助手解决方案。 【免费下载链接】livekit End-to-end …

作者头像 李华
网站建设 2026/5/6 1:46:21

MMDeploy模型部署全攻略:从零到生产环境的完整指南

MMDeploy模型部署全攻略&#xff1a;从零到生产环境的完整指南 【免费下载链接】mmdeploy OpenMMLab Model Deployment Framework 项目地址: https://gitcode.com/gh_mirrors/mm/mmdeploy 你是否曾经遇到过这样的困境&#xff1a;训练了一个优秀的AI模型&#xff0c;却不…

作者头像 李华