密室逃生游戏
题目
小强增在参加《密室逃生》游戏,当前关卡要求找到符合给定 密码 K(升序的不重复小写字母组成) 的箱子,
并给出箱子编号,箱子编号为 1~N
。
每个箱子中都有一个 字符串 s ,字符串由大写字母、小写字母、数字、标点符号、空格组成,
需要在这些字符串中找到所有的字母,忽略大小写后排列出对应的密码串儿,并返回匹配密码的箱子序号。
提示:
满足条件的箱子不超过 1 个
输入
第一行为 key 的字符串,
第二行为箱子 boxes,为数组样式,以逗号分隔
箱子 N 数量满足 1≤N≤10000 ,
s 长度满足 0≤s.length≤50 ,
密码为仅包含小写字母的升序字符串,且不存在重复字母,
密码 K 长度 K.length , 1≤K.length≤26
输出
返回对应箱子编号
如不存在符合要求的密码箱,则返回 -1
示例一
输入
abc
s, sdf134 A2c4b
输出
2
说明
第 2 个箱子中的 Abc
,符合密码 abc
示例二
输入
abc
s,sdf134 A2c4bd 523[]
输出
-1
说明
第 2 个箱子中的 Abcd
,与密码不完全匹配,不符合要求
备注
箱子中字符拼出的字符串与密码的匹配忽略大小写,且要求与密码完全匹配,如密码 abc
匹配 aBc
,但是密码 abc
不匹配 abcd
编码思路
- 解析输入,将字符串拆分成变量。
- 使用循环遍历第二个字符串的子字符串。
- 对于每个子字符串,将所有小写字母加入到一个 set 数据结构中。
- 如果这个 set 中的字符数等于第一个字符串的长度,那么就将 set 中的字符按字典序排序,与第一个字符串比较是否相同。
- 如果相同,则返回当前子字符串的索引。如果循环结束后没有找到匹配的子字符串,则返回 -1。