【华为OD机试真题】字母组合

题目描述

每个数字关联多个字母,关联关系如下:

  • 0 关联 “a”,”b”,”c”
  • 1 关联 “d”,”e”,”f”
  • 2 关联 “g”,”h”,”i”
  • 3 关联 “j”,”k”,”l”
  • 4 关联 “m”,”n”,”o”
  • 5 关联 “p”,”q”,”r”
  • 6 关联 “s”,”t”
  • 7 关联 “u”,”v”
  • 8 关联 “w”,”x”
  • 9 关联 “y”,”z”

输入一串数字后,通过数字和字母的对应关系可以得到多个字母字符串(要求按照数字的顺序组合字母字符串);

屏蔽字符串:屏蔽字符串中的所有字母不能同时在输出的字符串出现,如屏蔽字符串是abc,则要求字符串中不能同时出现a,b,c,但是允许同时出现a,b或a,c或b,c等;

给定一个数字字符串和一个屏蔽字符串,输出所有可能的字符组合;

例如输入数字字符串78和屏蔽字符串ux,输出结果为uw,vw,vx;数字字符串78,可以得到如下字符串uw,ux,vw,vx;由于ux是屏蔽字符串,因此排除ux,最终的输出是uw,vw,vx;

输入描述

第一行输入为一串数字字符串,数字字符串中的数字不允许重复,数字字符串的长度大于0,小于等于5;

第二行输入是屏蔽字符串,屏蔽字符串的长度一定小于数字字符串的长度,屏蔽字符串中字符不会重复;

输出描述

输出可能的字符串组合

注:字符串之间使用逗号隔开,最后一个字符串后携带逗号

测试样例1

输入

78
ux

输出

uw,vw,vx,

测试样例2

输入

78
x

输出

uw,vw,

解题思路

要解决这个问题,我们首先需要理解数字与字母之间的映射关系,并生成基于给定数字字符串的所有字母组合。之后,我们需要根据屏蔽字符串过滤这些组合,确保没有任何组合完全包含屏蔽字符串中的所有字符。

具体步骤如下:

  1. 根据输入的数字字符串,使用字母映射关系生成所有可能的字符组合。
  2. 过滤这些组合,排除那些包含屏蔽字符串中所有字母的组合。
  3. 输出剩下的组合。

Python代码解析

from itertools import product


def generate_combinations(digits, block_str):
    # 映射关系表
    digit_to_chars = {
        '0': ['a', 'b', 'c'],
        '1': ['d', 'e', 'f'],
        '2': ['g', 'h', 'i'],
        '3': ['j', 'k', 'l'],
        '4': ['m', 'n', 'o'],
        '5': ['p', 'q', 'r'],
        '6': ['s', 't'],
        '7': ['u', 'v'],
        '8': ['w', 'x'],
        '9': ['y', 'z']
    }

    # 根据输入的数字串获取字符列表
    groups = [digit_to_chars[digit] for digit in digits]

    # 使用 product 生成所有可能的组合
    all_combinations = [''.join(comb) for comb in product(*groups)]

    # 筛选组合:不能包含屏蔽字符串中的所有字符
    block_set = set(block_str)
    valid_combinations = []

    for comb in all_combinations:
        # 检查当前组合是否包含屏蔽字符串中的所有字符
        comb_set = set(comb)
        if not block_set.issubset(comb_set):
            valid_combinations.append(comb)

    return valid_combinations


if __name__ == "__main__":
    digits = input().strip()
    block_str = input().strip()

    combinations = generate_combinations(digits, block_str)
    output = ','.join(combinations) + ","
    print(output)
#华为OD##华为OD机考##华为OD机试真题##华为OD机试算法题库##华为OD题库#
全部评论

相关推荐

昨天 16:03
已编辑
门头沟学院 golang
查看25道真题和解析
点赞 评论 收藏
分享
总共四轮技术面(实际三面,但一面操作很迷,说算两面)+hr面一二面一上来手撕算法,给你一个有障碍物的网格,放棋子,不能相邻,求放置棋子的所有情况(说不放棋子也算一种情况)。刚看这题时有点像八皇后,但是不限定棋子,尝试用回溯写了下,没写出来。中途面试官说有事,临时走了,然后又来了一个面试官(直接懵逼)。向面试官说明情况后,面试官也不清楚情况,然后正常开始面试面试难度不大,聊了下项目,说他们做平台开发的也要写前端,问我会不会react(不会)。后面好像就问了一些简单的八股文。算法:镜像二叉树(没写出来,递归没想出来,用队列层次遍历发现也有问题)反问有几轮面试,他说三四面吧,前面那应该也算一次二道算法都没写出来,本以为凉了,结果收到了下一面的通知三面一个小姐姐(技术面遇到小姐姐着实有点吃惊)还是简单的八股文,网络、数据库这些。tcp连接中连接失败的原因有哪些(没答好)其他问题也忘了,整体难度不大。算法:三数之和(求最接近target的),二叉树先序遍历转双向链表,直接在二叉树的基础上改变左右指针转(还好上次面试完恶补了下二叉树的题)四面聊项目,如何提高高可用,答集群,用nginx做负载均衡,nginx服务器挂了怎么办,nginx服务器集群(后续接着问,没答好)后面也聊了一些八股算法:反转链表,遍历写完,要求再递归写,递归用了一个全局遍历保存了反转后的头节点,要求禁止用全局变量,最后在面试官的提示下写出来hr面自我介绍,是否愿意转语言了解旷视吗相对其他公司怎么选,后面改问平台、薪资、地域、工作内容四者我最看重啥(答的平台)薪资期望,明确告诉我14薪,每月多少没确定目前有其他offer吗反问:武汉研发中心情况(目前200人左右,还在扩大,在江夏区未来城)然后介绍了福利情况,早9,晚6,双休,年假10天,病假5天,一个月700饭补,加班会有额外饭补,车补。多久能出结果?旷视2025届校招启动啦!这是面向全球高校毕业生推出的一项尖端人才招募计划九个职位,两大城市米哈游招聘期待最优秀的你与我们一起共同打造AI新纪元!【网申地址】https://app.mokahr.com/campus_apply/megviihr/38642?recommendCode=DS87a6UM#/jobs【内推码】DS87a6UM投递的uu留言下姓名缩写和岗位,我会尽力跟进~(czy+产品经理)
旷视
|
校招
|
73个岗位
点赞 评论 收藏
分享
点赞 1 评论
分享
牛客网
牛客企业服务