leecode100-划分区间-贪心算法

题目

解法

cpp 复制代码
class Solution:
    def partitionLabels(self, s: str) -> List[int]:
        #记录每个字母的最后出现的下标i
        last = {}
        for i,c in enumerate(str):
            last.append(c:i)
        ans = []
        start = end = 0
        for i, c in enumerate(s):
            end = max(end, last[c])#不断拉长当前区间的最后的位置
            if end == i:#如果扫描到了,说明当前区间所有字母的最后位置都被包含到了 则区间划分好了
                ans.append(end - start + 1)
                start = i+1
        return ans
        
相关推荐
_日拱一卒14 分钟前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
珂朵莉MM44 分钟前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
Omics Pro1 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
voidmort2 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法
人道领域2 小时前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法
QiLinkOS3 小时前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
小白兔奶糖ovo4 小时前
【Leetcode】231. 2的幂
linux·算法·leetcode
xiaoxiaoxiaolll4 小时前
《Light: Science & Applications》合并BIC实现80倍阈值单模运行:超紧凑光子晶体激光器新突破
人工智能·算法·机器学习
Peter·Pan爱编程4 小时前
14. Lambda 表达式:随手可写的函数对象
c++·算法·ai编程
-To be number.wan4 小时前
算法日记 | 暴力枚举
学习·算法