763.划分字母区间

题目描述

题目描述

题解(贪心算法)

思路

思路

代码

java 复制代码
class Solution {
    public List<Integer> partitionLabels(String s) {
        // 用于记录每个小写字母最后一次出现的索引位置
        int[] last = new int[26];
        int length = s.length();
        
        // 第一次遍历:记录每个字母最后出现的下标
        for (int i = 0; i < length; i++) {
            last[s.charAt(i) - 'a'] = i;
        }
        
        List<Integer> partition = new ArrayList<>();
        int start = 0; // 当前片段的起始位置
        int end = 0;   // 当前片段的结束位置
        
        // 第二次遍历:利用贪心思想划分区间
        for (int i = 0; i < length; i++) {
            // 更新当前片段必须包含的最远位置
            end = Math.max(end, last[s.charAt(i) - 'a']);
            
            // 如果当前索引走到了当前片段的最远位置,说明可以安全地切分了
            if (i == end) {
                partition.add(end - start + 1);
                // 更新下一个片段的起始位置
                start = end + 1;
            }
        }
        
        return partition;
    }
}

复杂度分析

  • 时间复杂度:O(N)O(N)O(N),其中 NNN 是字符串的长度。我们需要遍历两次字符串,第一次记录最后出现位置,第二次进行区间划分。对常数大小的字母表(26个)的访问时间是 O(1)O(1)O(1),整体是线性时间复杂度
  • 空间复杂度:O(∣Σ∣)O(|\Sigma|)O(∣Σ∣),其中 Σ\SigmaΣ 是字符集。题目中说明字符串只包含小写英文字母,因此我们需要一个大小为 26 的数组来记录字母的最后出现位置,空间复杂度为 O(1)O(1)O(1)(即 O(26)O(26)O(26) 常数级别)。返回值不计入空间复杂度
相关推荐
JieE21211 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack2019 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树20 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架