字符串 S
由小写字母组成。我们要把这个字符串划分为尽可能多的片段,同一个字母只会出现在其中的一个片段。返回一个表示每个字符串片段的长度的列表。
示例 1:
输入: S = "ababcbacadefegdehijhklij" 输出: [9,7,8] 解释: 划分结果为 "ababcbaca", "defegde", "hijhklij"。 每个字母最多出现在一个片段中。 像 "ababcbacadefegde", "hijhklij" 的划分是错误的,因为划分的片段数较少。
注意:
S
的长度在[1, 500]
之间。S
只包含小写字母'a'
到'z'
。
基本思路:
- 维护一个 End 变量,这个变量表示的是 某个字母在这个字符串中最后出现的位置的下标。
- 从下标为0的位置开始,首先找到下标为0的字母的End,在该题中a对应的End为 8.
- 在0到8之间遍历,对每一个字符更新End 更新的原则是 谁大就用谁的End。
- 最后将End - Start,Start是该子串开头的字母的下标。更新Start。
class Solution {
public:
vector<int> partitionLabels(string S) {
vector<int> Hash(26,0);
vector<int> Res;
// 一个Hash表名,用于储存每个字母的End
for(int i=0;i<S.size();i++){
Hash[S[i]-'a']=max(Hash[S[i]-'a'],i);
}
int Start = 0, End = -1;
for(int i = 0; i<S.size(); i++){
// 更新End
End = max(Hash[S[i]-'a'], End);
// 如果已经已经遍历到End了,那么就说明已经找到了一个符合条件的结果
if(i == End){
Res.push_back(End - Start + 1);
Start = End + 1;
}
}
return Res;
}
};