LeetCode 热题 100 之 763.划分字母区间

作者:逆境不可逃

你的支持是我的动力,谢谢!!!

解题思路:贪心算法

  1. 先遍历一次字符串,记录每个字符最后一次出现的下标。
  2. 再遍历字符串,维护当前片段的起始位置 start 和当前片段内所有字符的最远出现位置 end
  3. 当遍历到 end 时,说明当前片段结束,记录长度 end - start + 1,并更新 start 为下一个位置。

Java 代码实现

复制代码
class Solution {
    public List<Integer> partitionLabels(String s) {
        int[] last = new int[26]; // 记录每个字母最后出现的位置
        int n = s.length();
        for (int i = 0; i < n; i++) {
            last[s.charAt(i) - 'a'] = i;
        }
        
        List<Integer> res = new ArrayList<>();
        int start = 0, end = 0;
        for (int i = 0; i < n; i++) {
            end = Math.max(end, last[s.charAt(i) - 'a']);
            if (i == end) { // 到达当前片段的终点
                res.add(end - start + 1);
                start = i + 1;
            }
        }
        return res;
    }
}

复杂度分析

  • 时间复杂度:O (n),两次线性遍历字符串。
  • 空间复杂度:O (1),仅使用大小为 26 的数组(小写字母数量),满足常量空间要求。

示例验证

  • 示例 1s = "ababcbacadefegdehijhklij"

    • 各字母最后位置:a=8, b=5, c=7, d=14, e=15, f=11, g=13, h=19, i=22, j=23, k=20, l=21
    • 遍历过程:
      • i=0 → end=8;i=8 时,片段长度 9(0-8)
      • i=9 → end=15;i=15 时,片段长度 7(9-15)
      • i=16 → end=23;i=23 时,片段长度 8(16-23)
    • 输出:[9,7,8]
  • 示例 2s = "eccbbbbdec"

    • 各字母最后位置:e=9, c=8, b=6, d=9
    • 遍历到 i=9 时才到达 end,片段长度 10
    • 输出:[10]
相关推荐
不知名的忻几秒前
红黑树(简易版)
算法·红黑树
NQBJT3 分钟前
万字拆解 NeckFix:AI 脖子前倾检测的算法原理与工程实现
人工智能·算法
jaychouchannel8 分钟前
Python 常用排序算法详解
算法
数智工坊9 分钟前
【Inner Monologue论文阅读】: 首次将大语言模型嵌入机器人控制闭环,实现自我反思和动态行为调整
论文阅读·人工智能·算法·语言模型·机器人·无人机
为何创造硅基生物1 小时前
C 语言 typedef 结构体私有化
c语言·开发语言·算法
yzx9910131 小时前
递归算法入门:像俄罗斯套娃一样思考
人工智能·算法
心中有国也有家1 小时前
从零上手 CANN 学习中心:像逛技术便利店一样学昇腾
学习·算法·开源
oo哦哦1 小时前
搜索矩阵系统的最短路密码:用Dijkstra算法和网络流理论,解释为什么你做了1000个关键词,流量还不如别人30个
网络·算法·矩阵
Matlab程序猿小助手1 小时前
【MATLAB源码-第319期】基于matlab的帝王蝶优化算法(MBO)无人机三维路径规划,输出做短路径图和适应度曲线.
开发语言·算法·matlab
图码1 小时前
二分查找进阶:如何在有序数组中快速找到Upper Bound?
数据结构·算法·面试·分类·柔性数组