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]
相关推荐
We་ct2 小时前
LeetCode 46. 全排列:深度解析+代码拆解
前端·数据结构·算法·leetcode·typescript·深度优先·回溯
MicroTech20252 小时前
微算法科技(NASDAQ:MLGO)量子PBFT改进技术:重构联盟链共识的效率与安全
科技·算法·重构
程序员小明儿2 小时前
量子计算探秘:从零开始的量子编程与算法之旅 · 第二篇
算法·量子计算
kronos.荒2 小时前
LRUCache缓存实现
算法·缓存·哈希算法
参.商.2 小时前
【Day32】704. 二分查找 34. 在排序数组中查找元素的第一个和最后一个位置
leetcode·golang
lihao lihao2 小时前
OJ管理系统后端测试报告
算法
@insist1232 小时前
软件设计师-算法核心考点:五大特性与复杂度分析(含主定理)
算法·软考·软件设计师·软件水平考试
wuqingshun3141592 小时前
蓝桥杯 无影之谜
算法·职场和发展·蓝桥杯
武帝为此2 小时前
【专家系统介绍】
人工智能·算法