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]
相关推荐
ja哇40 分钟前
大厂面试高频八股
java·面试·职场和发展
踩坑记录1 小时前
leetcode hot100 寻找两个正序数组的中位数 hard 二分查找 双指针
leetcode
旖-旎1 小时前
深搜练习(电话号码字母组合)(3)
c++·算法·力扣·深度优先遍历
谭欣辰1 小时前
C++快速幂完整实战讲解
算法·决策树·机器学习
Mr_pyx1 小时前
【LeetHOT100】随机链表的复制——Java多解法详解
算法·深度优先
AIFarmer1 小时前
【无标题】
开发语言·c++·算法
AGV算法笔记2 小时前
CVPR 2025 最新感知算法解读:GaussianLSS 如何用 Gaussian Splatting 重构 BEV 表示?
算法·重构·自动驾驶·3d视觉·感知算法·多视角视觉
勤劳的进取家2 小时前
数据链路层基础
网络·学习·算法
Advancer-3 小时前
第二次蓝桥杯总结(上)
java·算法·职场和发展·蓝桥杯
ん贤3 小时前
加密算法(对称、非对称、哈希、签名...)
算法·哈希算法