20天拿下华为OD笔试之【哈希集合】2023Q1A-寻找关键钥匙【欧弟算法】全网注释最详细分类最全的华为OD真题题解】

【哈希集合】2023Q1A-寻找关键钥匙

题目描述与示例

题目描述

小强正在参加《密室逃生》游戏,当前关卡要求找到符合给定密码 K(升序的不重复小写字母组成)的箱子,并给出箱子编号,箱子编号为 1~N

每个箱子中都有一个字符串 s,字符串由大写字母,小写字母,数字,标点符号,空格组成,需要在这些字符串中找出所有的字母,忽略大小写且去重后排列出对应的密码串,并返回匹配密码的箱子序号。

注意:满足条件的箱子不超过 1 个。

输入描述

第一行为表示密码 K 的字符串

第二行为一系列箱子 boxes,为字符串数组样式,以空格分隔

箱子 N 数量满足 1<=N<=10000,代表每一个箱子的字符串 s 的长度满足 0 <= s.length <= 50,密码为仅包含小写字母的升序字符串,且不存在重复字母,密码 K 长度满足1 <= K.length <= 26

输出描述

返回对应箱子编号,如不存在符合要求的密码箱,则返回-1

补充说明

箱子中字符拼出的字符串与密码的匹配忽略大小写,且要求与密码完全匹配,如密码 abc 匹配 aBc,但是密码 abc 不匹配 abcd

示例 1

输入

abc
s,sdf134 A2c4b

输出

2

说明

第 2 个箱子中的 Abc,符合密码 abc

示例 2

输入

abc
s,sdf134 A2c4bd 523[]

输出

-1

说明

2 个箱子中的 Abcd,与密码不完全匹配,不符合要求。

解题思路

本题思路非常直接。由于密码K不包含重复字符,每一个箱子字符串s也要做去重处理,因此我们可以直接分别用哈希集合K_sets_set来表示密码和箱子字符串。

遍历boxes中的每一个字符串s,并且挑选出其中的所有字母ch,并做ch.lower()即转为小写的处理,再所有转为小写的字母构建为s_set,再比较K_sets_set是否完全相等即可。若相等,则该箱子字符串s所对应的编号i+1(之所以+1是因为箱子的编号是从1而不是从0开始的)即为答案。

**思考:**如果稍微修改本题的条件,即箱子字符串不做去重处理,即s = "aa"K = "a"不能匹配,那么应该如何修改代码?

时空复杂度

时间复杂度:O(k+NM)

空间复杂度:O(k+M)

其中N为boxes的长度,Ms的平均长度,kK的长度。

代码

# 题目:2023Q1A-寻找关键钥匙
# 分值:100
# 作者:闭着眼睛学数理化
# 算法:哈希集合
# 代码有看不懂的地方请直接在群上提问

K = input()                 # 输入密码字符串K
boxes = input().split()     # 输入箱子字符串数组boxes

ans = -1                    # 初始化答案为-1
K_set = set(K)              # 得到密码字符串所对应的集合

# 遍历boxes字符串中的所有索引i和字符串s
for i, s in enumerate(boxes):
    # 得到字符串s中所有字母的集合,其中大写字母均转化为小写字母
    s_set = {ch.lower() for ch in s if ch.isalpha()}
    
    if K_set == s_set:      # 如果该集合与密码集合相等,则得到了符合要求的箱子编号
        ans = i+1           # 注意箱子编号是从1开始的
        break               # 因为只有一个箱子满足要求,所以此时直接退出循环即可

print(ans)

华为OD算法冲刺训练
华为OD算法冲刺训练目前开始常态化报名!目前已服务100+同学成功上岸!

课程讲师为全网50w+粉丝编程博主@吴师兄学算法 以及小红书头部编程博主@闭着眼睛学数理化

每期人数维持在20人内,保证能够最大限度地满足到每一个同学的需求,达到和1v1同样的学习效果!

30+天陪伴式学习,20+直播课时,300+动画图解视频,200+LeetCode经典题,100+华为OD真题,还有简历修改与模拟面试将为你解锁

可查看链接 OD算法冲刺训练课程表 & OD真题汇总(持续更新)

绿色聊天软件戳 sheepvipvip了解更多

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
题目描述: 给定一个整数数组nums和一个整数k,编写一个函数来判断数组中是否存在 k 个不同的索引i、j、l和m,使得nums[i] + nums[j] == nums[l] + nums[m]。如果存在,返回true;否则,返回false。 解题思路: 首先,我们可以使用4个for循环来遍历所有可能的索引组合,然后判断它们对应元素的和是否相等。但是这种方法的时间复杂度为O(n^4),显然效率很低。因此,我们可以优化思路,使用哈希表来存储数组元素的和及其对应的索引,然后遍历所有可能的组合,判断是否存在相等的和。 具体步骤: 1. 创建一个HashMap<Integer, List<int[]>>来存储和及其对应的索引组合; 2. 遍历数组nums的所有可能组合,计算两个元素的和,并将和及其对应的索引组合存入HashMap中; 3. 再次遍历数组nums,对于每个元素,查找是否存在k-1个不同的索引对应的和在HashMap中,如果存在,则返回true; 4. 遍历结束后若未找到满足条件的索引组合,则返回false。 代码实现: ```java public static boolean checkKSum(int[] nums, int k) { Map<Integer, List<int[]>> map = new HashMap<>(); for (int i = 0; i < nums.length; i++) { for (int j = i + 1; j < nums.length; j++) { int sum = nums[i] + nums[j]; if (!map.containsKey(sum)) { map.put(sum, new ArrayList<>()); } map.get(sum).add(new int[]{i, j}); } } for (int i = 0; i < nums.length; i++) { for (int j = i + 1; j < nums.length; j++) { int target = nums[i] + nums[j]; if (map.containsKey(target)) { List<int[]> list = map.get(target); for (int[] pair : list) { if (pair[0] != i && pair[1] != i && pair[0] != j && pair[1] != j) { return true; } } } } } return false; } ``` 以上就是对2023华为od机试真题java【k数之和】的回答,希望对您有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值