1024节日快乐
字符串 S 由小写字母组成。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。返回一个表示每个字符串片段的长度的列表。
示例:
输入:S = “ababcbacadefegdehijhklij”
输出:[9,7,8]
解释:
划分结果为 “ababcbaca”, “defegde”, “hijhklij”。
每个字母最多出现在一个片段中。
像 “ababcbacadefegde”, “hijhklij” 的划分是错误的,因为划分的片段数较少。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/partition-labels
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
失忆解法
class Solution {
public List<Integer> partitionLabels(String S) {
int length = S.length();
Map<Character, Integer> map = new HashMap<>();
for (int i = 0; i < length; i++) {
map.put(S.charAt(i), i);
}
List<Integer> list = new ArrayList<>();
int start = 0, end = 0;
for (int i = 0; i < length; i++) {
end = Math.max(end, map.get(S.charAt(i)));
if (i == end) {
list.add(end - start + 1);
start = end + 1;
}
}
return list;
}
}
执行结果:通过显示详情执行用时:8 ms, 在所有 Java 提交中击败了34.35%的用户内存消耗:38.4 MB, 在所有 Java 提交中击败了25.81%的用户
官方解法
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<Integer>();
int start = 0, 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;
}
}
执行结果:通过显示详情执行用时:3 ms, 在所有 Java 提交中击败了96.91%的用户内存消耗:36.7 MB, 在所有 Java 提交中击败了98.10%的用户。