关联子串
该比赛已结束,您无法在比赛模式下递交该题目。您可以点击“在题库中打开”以普通模式查看和递交本题。
题目解析和算法源码
华为OD机试 - 关联子串(Java & JS & Python & C & C++)_关联子串华为od 深度搜索_伏城之外的博客-CSDN博客
题目描述
给定两个字符串 str1
和 str2
,如果字符串 str1
中的字符,经过排列组合后的字符串中,只要有一个字符串是 str2
的子串,则认为 str1
是 str2
的关联子串。
若 str1
是 str2
的关联子串,请返回子串在 str2
的起始位置;
若不是关联子串,则返回 -1
。
输入描述
输入两个字符串,分别为题目中描述的 str1
、str2
。
输出描述
若 str1
是 str2
的关联子串,请返回子串在 str2
的起始位置;
若不是关联子串,则返回 -1
。
若 str2
中有多个 str1
的组合子串,请返回最小的起始位置。
备注
- 输入的字符串只包含小写字母;
- 两个字符串的长度范围[1, 100000]之间;
用例1
输入
abc efghicbaiii
输出
5
说明
str2包含str1的一种排列组合("cab"),此组合在str2的字符串起始位置为5(从0开始计数)
用例2
输入
abc efghiccaiii
输出
-1
说明
“abc”字符串中三个字母的各种组合(abc、acb、bac、bca、cab、cba),str2中均不包含,因此返回-1
华为OD模拟机考(E卷)【公开赛】 2025/2/20 21:00
- 状态
- 已结束
- 规则
- IOI
- 题目
- 3
- 开始于
- 2025-2-20 21:00
- 结束于
- 2025-2-20 23:30
- 持续时间
- 2.5 小时
- 主持人
- 参赛人数
- 10