最新华为OD机试真题-英文单词联想(100分)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员

✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解

👏 感谢大家的订阅➕ 和 喜欢💗

最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,支持题目在线评测

最新华为OD机试目录: https://www.nowcoder.com/discuss/636153620743897088?sourceSSR=users

📎在线评测链接

英文单词联想(100分)

alt

🌍 评测功能需要 =>订阅专栏<= 后联系清隆解锁~

🍓OJ题目截图

alt

🍿 英文单词联想

问题描述

K小姐是一家科技公司的产品经理,她最近负责开发一款英文输入法。其中一个重要功能是单词联想,即根据用户输入的单词前缀,从已输入的英文语句中联想出用户想输入的单词,并按字典序输出联想到的单词序列。如果无法联想到任何单词,则输出用户输入的单词前缀。

需要注意以下几点:

  1. 英文单词联想时,区分大小写。
  2. 缩略形式如"don't",判定为两个单词,"don"和"t"。
  3. 输出的单词序列,不能有重复单词,且只能是英文单词,不能有标点符号。

输入格式

输入为两行:

  • 第一行输入一段由英文单词 和标点符号组成的语句
  • 第二行为一个英文单词前缀

其中 , ,

输出格式

输出符合要求的单词序列或单词前缀,存在多个时,单词之间以单个空格分割。

样例输入 1

I love you
He

样例输出 1

He

样例解释 1

从用户已输入英文语句"I love you"中提炼出"I"、"love"、"you"三个单词,接下来用户输入"He",从已输入信息中无法联想到任何符合要求的单词,因此输出用户输入的单词前缀。

样例输入 2

The furthest distance in the world, ls not between life and death, But when I stand in front of you, Yet you don't know that I love you.
f

样例输出 2

front furthest

样例解释 2

从用户已输入英文语句"The furthest distance in the world, Is not between life and death, But when I stand in front of you, Yet you don't know that I love you"中提炼出的单词,符合"f"作为前缀的有"furthest"和"front",按字典序排序并在单词间添加空格后输出,结果为"front furthest"。

数据范围

题解

本题的关键在于如何从给定的英文语句中提取出所有单词,并根据单词前缀进行过滤和排序。我们可以使用正则表达式或字符串分割的方法将语句拆分为单词列表,然后遍历单词列表,找出以给定前缀开头的单词,并将它们按字典序排列输出。

如果无法找到任何符合要求的单词,则直接输出给定的单词前缀。需要注意的是,在处理缩略形式时,应将其拆分为多个单词进行处理。

参考代码

  • Python
import re

def soln(sentence, prefix):
    # 使用正则表达式提取所有单词
    words = re.findall(r'\w+', sentence.lower())
    
    # 过滤并排序符合前缀的单词
    filtered_words = sorted([word for word in words if word.startswith(prefix.lower())])
    
    # 如果没有符合要求的单词,输出前缀
    if not filtered_words:
        return prefix
    else:
        return ' '.join(filtered_words)

# 读取输入
sentence = input()
pr

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

最新华为OD机试-E+D卷 文章被收录于专栏

本专栏给大家提供了华为2024最新华为OD-E/D卷的题目汇总和(Java/Cpp/Python)三语言解析 + 部分题目提供OJ在线评测

全部评论

相关推荐

1 1 评论
分享
牛客网
牛客企业服务