news 2026/7/1 21:40:29

华为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/7/1 10:48:53

终极指南:3分钟用Files文件管理器搞定SSH远程服务器文件操作

终极指南&#xff1a;3分钟用Files文件管理器搞定SSH远程服务器文件操作 【免费下载链接】Files Building the best file manager for Windows 项目地址: https://gitcode.com/gh_mirrors/fi/Files 还在为复杂的SSH命令行操作而烦恼吗&#xff1f;Files文件管理器让远程…

作者头像 李华
网站建设 2026/7/1 13:21:49

Open-AutoGLM如何守护未成年人隐私?这3个关键设置你必须掌握

第一章&#xff1a;Open-AutoGLM如何守护未成年人隐私&#xff1f;这3个关键设置你必须掌握在人工智能应用日益普及的背景下&#xff0c;Open-AutoGLM 作为一款强大的语言模型工具&#xff0c;其在处理未成年人相关数据时的隐私保护机制尤为重要。正确配置系统设置不仅能符合《…

作者头像 李华
网站建设 2026/6/30 17:55:24

Open-AutoGLM权限管理体系深度解析(20年专家实战经验倾囊相授)

第一章&#xff1a;Open-AutoGLM权限分级管控概述Open-AutoGLM作为面向企业级AI应用的自动化语言模型平台&#xff0c;其核心安全机制依赖于精细化的权限分级管控体系。该体系通过角色、资源与操作的三元组控制模型&#xff0c;实现对用户行为的最小权限约束&#xff0c;保障系…

作者头像 李华
网站建设 2026/7/2 0:18:33

5分钟快速上手Catch2事件监听器:终极测试监控解决方案

5分钟快速上手Catch2事件监听器&#xff1a;终极测试监控解决方案 【免费下载链接】Catch2 A modern, C-native, test framework for unit-tests, TDD and BDD - using C14, C17 and later (C11 support is in v2.x branch, and C03 on the Catch1.x branch) 项目地址: https…

作者头像 李华