【LeetCode热题100】【贪心算法】划分字母区间

题目链接:763. 划分字母区间 - 力扣(LeetCode)

要将一个字符串划分为多个子串,要求每个字母只能出现在一个子串里面

如果一个字母的当前位置是它在这个字符串里面最后一次出现的位置,那么这里就应该划分出来成为子串

可以先用一个数组记录每个字母的最后出现的位置,然后再次遍历字符串,如果当前字母的位置就是该字母最后出现的位置,那么此处应该分离

复制代码
class Solution {
public:
    vector<int> partitionLabels(string s) {
        int last[26];
        for (int i = 0; s[i]; ++i)
            last[s[i] - 'a'] = i;
        int begin = 0, end = 0;
        vector<int> ans;
        for (int i = 0; s[i]; ++i) {
            end = max(end, last[s[i] - 'a']);
            if (i == end) {
                ans.push_back(end - begin + 1);
                begin = end + 1;
            }
        }
        return ans;
    }
};
相关推荐
2301_7644413315 分钟前
三维建筑非法入侵情景推演
python·学习·算法
唯道行28 分钟前
计算机图形学·19 Shadings in OpenGL
人工智能·算法·计算机视觉·几何学·计算机图形学·opengl
初夏睡觉1 小时前
全排列题解
算法·深度优先·图论
在下赵某人1 小时前
概率数据结构的设计原理与误差分析
数据结构·算法·哈希算法
CoderYanger1 小时前
递归、搜索与回溯-综合练习:19.目标和
java·算法·leetcode·1024程序员节
mit6.8241 小时前
dfs|mask^翻转
算法
SKYDROID云卓小助手2 小时前
三轴云台之控制协同技术
服务器·网络·图像处理·人工智能·算法
The Last.H2 小时前
Educational Codeforces Round 185 (Rated for Div. 2)A-C
c语言·c++·算法
fengfuyao9852 小时前
匈牙利算法的MATLAB实现
java·算法·matlab
路过君_P3 小时前
C++ 算法题解:迷宫寻路
c++·算法·深度优先