在Python中按顺序查找所有元音的最长子串的程序
假设我们有一个只有英文元音的字符串s,我们必须找到s的最长美丽子串的长度。如果我们找不到这样的子字符串,则返回0。如果字符串满足以下条件,则称其为美丽的字符串-
5个元音中的每一个都必须至少出现一次。
字母必须按字母顺序排序
因此,如果输入类似于s="aaioaaaaeiiouuooaauu",那么输出将是10,因为子字符串是美丽的"aaaaeiiouu"。
示例
让我们看看以下实现以获得更好的理解-
def solve(s):
vowels = ['a', 'e', 'i', 'o', 'u']
l, r, longest = 0, 0, 0
while (l < len(s)):
valid = True
for vowel in vowels:
valid &= (r < len(s) and s[r] == vowel)
while (r < len(s) and s[r] == vowel):
r += 1
if (valid):
longest = max(longest, r - l)
l = r
return longest
s = "aaioaaaaeiiouuooaauu"
print(solve(s))输入
"aaioaaaaeiiouuooaauu"输出结果
10
热门推荐
10 圣诞祝福语简短小学
11 祖国七十华诞简短祝福语
12 老师送的祝福语简短
13 生日祝福语大全女生简短
14 祝女性生日祝福语简短
15 牛年女神节祝福语简短
16 情人表白祝福语简短大气
17 老公开业祝福语简短
18 官宣新年祝福语简短