LeetCode热题100--763. 划分字母区间--中等

题目

给你一个字符串 s 。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。例如,字符串 "ababcc" 能够被分为 ["abab", "cc"],但类似 ["aba", "bcc"] 或 ["ab", "ab", "cc"] 的划分是非法的。

注意,划分结果需要满足:将所有划分结果按顺序连接,得到的字符串仍然是 s 。

返回一个表示每个字符串片段的长度的列表。

示例 1:

输入:s = "ababcbacadefegdehijhklij"

输出:[9,7,8]

解释:

划分结果为 "ababcbaca"、"defegde"、"hijhklij" 。

每个字母最多出现在一个片段中。

像 "ababcbacadefegde", "hijhklij" 这样的划分是错误的,因为划分的片段数较少。

示例 2:

输入:s = "eccbbbbdec"

输出:[10]

题解

java 复制代码
class Solution {
    public List<Integer> partitionLabels(String S) {
        char[] s = S.toCharArray();
        int n = s.length;
        int[] last = new int[26];
        for (int i = 0; i < n; i++) {
            last[s[i] - 'a'] = i; // 每个字母最后出现的下标
        }

        List<Integer> ans = new ArrayList<>();
        int start = 0, end = 0;
        for (int i = 0; i < n; i++) {
            end = Math.max(end, last[s[i] - 'a']); // 更新当前区间右端点的最大值
            if (end == i) { // 当前区间合并完毕
                ans.add(end - start + 1); // 区间长度加入答案
                start = i + 1; // 下一个区间的左端点
            }
        }
        return ans;
    }
}

解析

出自:本质是合并区间,简洁写法(Python/Java/C++/C/Go/JS/Rust)

java 复制代码
class Solution {  //定义一个新的解决方案类
    public List<Integer> partitionLabels(String S) {   //partitionLabels是接收字符串S的方法
        char[] s = S.toCharArray();  //将输入的字符串转换为字符数组's'
        int n = s.length;  //获取字符串的长度'n'并保存到变量中
			         int[] last = new int[26];   //初始化一个大小为26的整型数组,表示英文字母表中的每个字母的索引。这个将用于获取最后出现的下标值
        for(int i = 0; i < n; i++) {  //循环遍历整个s数组
            last[s[i] - 'a'] = i;   //每次迭代时,更新字符在输入字符串中的索引位置。这里通过计算字母在英文字母表中的索引值来实现。比如在最后出现了'd'字符,就找到了它的最远索引
        }
			 List<Integer> ans = new ArrayList<>();  //初始化一个空的数组列表以存储最终答案
        int start = 0, end = 0;   //定义变量start和end为区间的起点和终点。这两个点表示可能包含最多不重复字母的子串/区间,即我们要找的划分/区间
			 for(int i = 0; i < n; i++) {  //再次从头开始循环遍历整个s数组。这个循环用于确定每个可能区间的结束点
            end = Math.max(end, last[s[i] - 'a']);  //当前字母/字符的最后出现的位置和已经迄今为止找到的最远位置(比如'd'在这里表示一个子串中的最大索引,它将一直增加直到达到所有部分或数组末尾)
			 if(end == i) {  //如果当前确定的区间(从start到end之间包括这两个点)结束的位置等于当前迭代器'i'表示的字符,意味着没有重复/公共字母存在。因为在给定子串中只有这个部分包含所有唯一字母
                ans.add(end - start + 1);  //将长度加入答案列表(end-start+1,因为在Java中数组索引从0开始)
                start = i + 1;  //移动到下一个区间的起点。'i +1'确保我们向前移动一步到达下一个字母/字符的位置,并成为新的区间或子串的起始点
             }  
         }    
相关推荐
小O的算法实验室1 天前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
郭涤生1 天前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿1 天前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz1 天前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能1 天前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****1 天前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能1 天前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能1 天前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo1 天前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
Proxy_ZZ01 天前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法