在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 妈妈生日祝福语简短励志