Leetcode 763:划分字母区间
题目描述:
字符串 S 由小写字母组成。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。返回一个表示每个字符串片段的长度的列表。
示例:
输入:S = "ababcbacadefegdehijhklij"
输出:[9,7,8]
解释:
划分结果为 "ababcbaca", "defegde", "hijhklij"。
每个字母最多出现在一个片段中。
像 "ababcbacadefegde", "hijhklij" 的划分是错误的,因为划分的片段数较少。
思路:
题目的意思是分割后的每个字字符串内的字符都只在该子字符串内出现。所以在分割的时候可以使用贪心,遍历字符串,并找到当前字符出现的最晚位置last,对于当前字符位置与最晚出现位置last之间的字符,寻找它们字符出现的最晚位置,如果最晚位置超过last,更新last并且更新下一个起始位start。将last-start+1内的字符子串长度保存至结果数组中。
代码:
class Solution {
public List<Integer> partitionLabels(String s) {
int[] init=new int[26];
int n=s.length();
for(int i=0;i<n;i++){
init[s.charAt(i)-'a']=i;
}
List<Integer> res=new ArrayList<Integer>();
int start=0,end=0;
for(int i=0;i<n;i++){
end=Math.max(init[s.charAt(i)-'a'],end);//判断是否需要更新end
if(i==end){
res.add(end-start+1);
start=end+1;
}
}
return res;
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了