题目链接
英文链接:https://leetcode.com/problems/partition-labels/
中文链接:https://leetcode-cn.com/problems/partition-labels/
题目详述
字符串 S
由小写字母组成。我们要把这个字符串划分为尽可能多的片段,同一个字母只会出现在其中的一个片段。返回一个表示每个字符串片段的长度的列表。
示例 1:
1 | 输入: S = "ababcbacadefegdehijhklij" |
注意:
S
的长度在[1, 500]
之间。S
只包含小写字母'a'
到'z'
。
题目详解
贪心算法。
- 首先构建一个数组记录每个字符最后一次出现的位置。
- 用 end 来标记当前片段的结束位置。
- 遍历数组,并维护 end,如果此时下标刚好等于 end,说明这个片段到此为止结束。
- 为了统计每个片段的长度,还需要添加一个 start 标记当前片段的起始位置。
1 | public class LeetCode_00763 { |