题目链接:https://leetcode-cn.com/problems/partition-labels/
题目描述
字符串 S 由小写字母组成。我们要把这个字符串划分为尽可能多的片段,同一个字母只会出现在其中的一个片段。返回一个表示每个字符串片段的长度的列表。
示例 1:
输入: S = "ababcbacadefegdehijhklij"
输出: [9,7,8]
解释:
划分结果为 "ababcbaca", "defegde", "hijhklij"。
每个字母最多出现在一个片段中。
像 "ababcbacadefegde", "hijhklij" 的划分是错误的,因为划分的片段数较少。
注意:
- S的长度在[1, 500]之间。
- S只包含小写字母’a’到’z’。
思路
/*
* 贪心两次遍历O(n)
*/
class Solution {
public:
vector<int> partitionLabels(string S) {
vector<int> ret;
unordered_map<char, int> m;
for (int i = 0; i < S.size(); ++i)
m[S[i]] = i;
int maxPos = m[S[0]]; // 当前最远距离
int begin = 0; // 起始点
for (int i = 0; i < S.size(); ++i) {
if(m[S[i]] > maxPos)
maxPos = m[S[i]];
if(i == maxPos){
ret.push_back(maxPos+1 - begin);
begin = i+1;
}
}
return ret;
}
};
版权声明:本文为zjwreal原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。