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]
相关推荐
计算机安禾12 小时前
【数据结构与算法】第17篇:串(String)的高级模式匹配:KMP算法
c语言·数据结构·学习·算法·visual studio code·visual studio·myeclipse
大萌神Nagato12 小时前
力扣HOT100 Q146LRU缓存
算法·leetcode·缓存
源码之家12 小时前
大数据毕业设计汽车推荐系统 Django框架 可视化 协同过滤算法 数据分析 大数据 机器学习(建议收藏)✅
大数据·python·算法·django·汽车·课程设计·美食
Boop_wu12 小时前
[Java 算法] 哈希表(1)
leetcode·哈希算法·散列表
nianniannnn12 小时前
力扣 3.无重复字符的最长子串
c++·算法·leetcode
IT大师兄吖12 小时前
flux-2-Klein-BFS-换头换脸工作流 懒人整合包
算法·宽度优先
波哥学开发12 小时前
深入解析 BEV 图像色彩调整与伪彩色映射:从直方图统计到着色器实现
算法·图形学
西西弟13 小时前
最短路径之Floyd算法(数据结构)
数据结构·算法
小O的算法实验室13 小时前
2026年SEVC,直觉模糊不确定环境下求解绿色多物品固定费用五维运输问题的多目标进化算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
海海不瞌睡(捏捏王子)13 小时前
Unity A*寻路算法
算法·unity