欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 房产 > 建筑 > 力扣-贪心-763 划分字母区间

力扣-贪心-763 划分字母区间

2025/2/25 11:39:04 来源:https://blog.csdn.net/qq_45964225/article/details/145839039  浏览:    关键词:力扣-贪心-763 划分字母区间

思路

先统计字符串中每一个字母出现的最后下标,然后从end初始化为第一个字母出现的最后下标,在i<=end时,不断更新end,因为一旦囊括新的字母就最起码要遍历到新字母出现的最后下标,在i>end时,说明遍历完成,再重新赋值end即可

代码

class Solution {
public:vector<int> partitionLabels(string s) {map<char, int> letterPos;for(int i = 0; i < s.size();i++){letterPos[s[i]] = i;}int end = letterPos[s[0]];vector<int> res;int length = 0;for (int i = 0; i < s.size(); i++) {if (i <= end) {length++;end = max(end, letterPos[s[i]]);} else {res.push_back(length);length = 1;end = letterPos[s[i]];}}res.push_back(length);return res;}
};

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词