题意描述:
给你一个字符串 s 。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。
注意,划分结果需要满足:将所有划分结果按顺序连接,得到的字符串仍然是 s 。
返回一个表示每个字符串片段的长度的列表。
思路:
- 统计每一个字符最后出现的位置
- 从头遍历字符,并更新字符的最远出现下标,如果找到字符最远出现位置下标和当前下标相等了,则找到了分割点
完整C++代码如下:
class Solution {
public:
vector<int> partitionLabels(string s) {
int index[26] = {0};
for(int i = 0; i < s.size(); i++){
index[s[i] - 'a'] = i;
}
vector<int> res;
int left = 0;
int right = 0;
for(int i = 0; i < s.size(); i++){
right = max(right, index[s[i] - 'a']);
if(i == right){
res.emplace_back(right - left + 1);
left = i + 1;
}
}
return res;
}
};