写在前面python
今天这篇文章是贪心算法系列的第三篇--划分字母区间。算法
前文回顾:app
刷题汇总:学习
今日题目code
字符串 S 由小写字母组成。咱们要把这个字符串划分为尽量多的片断,同一个字母只会出如今其中的一个片断。返回一个表示每一个字符串片断的长度的列表。字符串
示例 1:
输入: S = "ababcbacadefegdehijhklij"
输出: [9,7,8]
解释:
划分结果为 "ababcbaca", "defegde", "hijhklij"。
每一个字母最多出如今一个片断中。
像 "ababcbacadefegde", "hijhklij" 的划分是错误的,由于划分的片断数较少。get
注意:
S的长度在[1, 500]之间。
S只包含小写字母'a'到'z'。it
题目分析
解决此题关键就是找到能分割的条件,对S的每一个字符进行判断,看是否此字符是被分割到另外一个字符中,从题目中获得每一个字母最多出如今一个片断中,那么从第一个字符开始,它的最后一个相同的字符必定在这个片断中,获得第一个条件:
当此字符在前面分割中出现,就不能当作分割点
只有这个条件就能够了吗?咱们再考虑一下,当前字符并无在前面分割的区间中出现,是否是能直接做为分割点呢?如下面的字符串为例进行分割。
“aaaaab cdaefgh”
当判断b的时候,先在前面已经分好的字符串aaaaa里面没有,符合找到的第一个条件,若是咱们把b当作新的分割点,很明显是错误的,由于在b后面的字符串里,又一次出现了a,当咱们以b做为分割点是不符合条件的,所以获得第二个限制条件:
分割点后面不能出现前面一个字符串中的字符。
进行了上面的分析可是能够用python作个弊,使用rindex()方法,从第一个字符开始,假设位置为a,用rindex方法找到最后一次出现的位置b,那么这个区间就为[a,b]。以后每一个字符都找最后一个位置,若是在区间以外则扩大区间,若是遍历到区间的最后一个位置,则结束,长度就为结束位置减开始位置加1。
代码实现
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
推荐阅读: