题目
字符串 S 由小写字母组成。我们要把这个字符串划分为尽可能多的片段,同一个字母只会出现在其中的一个片段。返回一个表示每个字符串片段的长度的列表。
示例 1:
输入: S = "ababcbacadefegdehijhklij"
输出: [9,7,8]
解释:
划分结果为 "ababcbaca", "defegde", "hijhklij"。
每个字母最多出现在一个片段中。
像 "ababcbacadefegde", "hijhklij" 的划分是错误的,因为划分的片段数较少。
注意:
S的长度在[1, 500]之间。S只包含小写字母'a'到'z'。
思路
要求同一个字母只会出现在其中的一个片段,那么从第一个字符开始,它的最后一个相同的字符一定在这个片段中。于是从第一个字符开始,假设位置为a,用rindex方法找到最后一次出现的位置b,那么这个区间就为[a,b]。之后每个字符都找最后一个位置,如果在区间之外则扩大区间,如果遍历到区间的最后一个位置,则结束,长度就为结束位置减开始位置加1。
python代码
class Solution:
def partitionLabels(self, S):
"""
:type S: str
:rtype: List[int]
"""
i = 0
res = []
while i < len(S):
start = i
end = S.rindex(S[i])
for j in range(i,len(S)):
last = S.rindex(S[j])
if last > end:
end = last
elif j == end:
res.append(end-start + 1)
i = end + 1
break
return res
本文介绍了一种算法,用于将由小写字母组成的字符串S划分为尽可能多的片段,确保每个字母仅在一个片段中出现。通过实例展示了如何使用该算法,并提供了Python实现代码。
187

被折叠的 条评论
为什么被折叠?



