news 2026/2/7 7:44:11

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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]

题解

classSolution{publicList<Integer>partitionLabels(StringS){char[]s=S.toCharArray();intn=s.length;int[]last=newint[26];for(inti=0;i<n;i++){last[s[i]-'a']=i;// 每个字母最后出现的下标}List<Integer>ans=newArrayList<>();intstart=0,end=0;for(inti=0;i<n;i++){end=Math.max(end,last[s[i]-'a']);// 更新当前区间右端点的最大值if(end==i){// 当前区间合并完毕ans.add(end-start+1);// 区间长度加入答案start=i+1;// 下一个区间的左端点}}returnans;}}

解析

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

classSolution{//定义一个新的解决方案类publicList<Integer>partitionLabels(StringS){//partitionLabels是接收字符串S的方法char[]s=S.toCharArray();//将输入的字符串转换为字符数组's'intn=s.length;//获取字符串的长度'n'并保存到变量中int[]last=newint[26];//初始化一个大小为26的整型数组,表示英文字母表中的每个字母的索引。这个将用于获取最后出现的下标值for(inti=0;i<n;i++){//循环遍历整个s数组last[s[i]-'a']=i;//每次迭代时,更新字符在输入字符串中的索引位置。这里通过计算字母在英文字母表中的索引值来实现。比如在最后出现了'd'字符,就找到了它的最远索引}List<Integer>ans=newArrayList<>();//初始化一个空的数组列表以存储最终答案intstart=0,end=0;//定义变量start和end为区间的起点和终点。这两个点表示可能包含最多不重复字母的子串/区间,即我们要找的划分/区间for(inti=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'确保我们向前移动一步到达下一个字母/字符的位置,并成为新的区间或子串的起始点}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/30 18:01:20

4步闪电出图:Qwen-Image-Lightning如何颠覆AI创作体验

4步闪电出图&#xff1a;Qwen-Image-Lightning如何颠覆AI创作体验 【免费下载链接】Qwen-Image-Lightning 项目地址: https://ai.gitcode.com/hf_mirrors/lightx2v/Qwen-Image-Lightning 在AI图像生成领域&#xff0c;速度与质量似乎总是一对矛盾体。传统扩散模型需要5…

作者头像 李华
网站建设 2026/2/6 0:01:15

Moovie.js视频播放器终极指南:打造专业级HTML5播放体验

Moovie.js视频播放器终极指南&#xff1a;打造专业级HTML5播放体验 【免费下载链接】moovie.js Movie focused HTML5 Player 项目地址: https://gitcode.com/gh_mirrors/mo/moovie.js Moovie.js是一款专为电影爱好者设计的现代化HTML5视频播放器&#xff0c;以其出色的字…

作者头像 李华
网站建设 2026/2/2 9:57:42

FaceFusion与ButterCMS集成:轻量级网站的内容增强

FaceFusion与ButterCMS集成&#xff1a;轻量级网站的内容增强 在今天的数字内容战场上&#xff0c;用户不再满足于静态图文。他们想要互动、个性化&#xff0c;甚至“看见未来的自己”——比如一键换脸到明星脸上&#xff0c;或预览十年后的容貌变化。而与此同时&#xff0c;越…

作者头像 李华
网站建设 2026/1/30 7:49:28

【稀缺技术指南】Open-AutoGLM中文编码问题破解:仅需调整这3个参数

第一章&#xff1a;Open-AutoGLM 中文输入乱码问题概述在使用 Open-AutoGLM 模型处理中文文本时&#xff0c;部分用户反馈在输入阶段出现中文字符显示为乱码的现象。该问题通常出现在数据预处理、模型加载或推理接口调用过程中&#xff0c;严重影响了中文语义的理解与生成质量。…

作者头像 李华
网站建设 2026/2/6 13:38:37

移动端动画架构终极指南:构建企业级组件化解决方案

移动端动画架构终极指南&#xff1a;构建企业级组件化解决方案 【免费下载链接】lottie-ios airbnb/lottie-ios: Lottie-ios 是一个用于 iOS 平台的动画库&#xff0c;可以将 Adobe After Effects 动画导出成 iOS 应用程序&#xff0c;具有高性能&#xff0c;易用性和扩展性强的…

作者头像 李华
网站建设 2026/2/4 19:40:22

5个VizTracer数据管理技巧:平衡性能与存储的终极指南

5个VizTracer数据管理技巧&#xff1a;平衡性能与存储的终极指南 【免费下载链接】viztracer VizTracer is a low-overhead logging/debugging/profiling tool that can trace and visualize your python code execution. 项目地址: https://gitcode.com/gh_mirrors/vi/viztr…

作者头像 李华