当前位置: 首页 > news >正文

LeetCode[中等] 763. 划分字母区间

给你一个字符串 s 。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。

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

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

思路 贪心算法

数组 last 存储每个字母最后出现的下标

利用滑动窗口,每次更新end指针,如果最后出现的下标 i == end,说明找到当前最大片段,则加入结果中,更新 start指针

public class Solution {public IList<int> PartitionLabels(string s) {int[] last = new int[26];for(int i = 0; i < s.Length; i++){last[s[i] - 'a'] = i;}List<int> result = new List<int>();int start = 0, end = 0;for(int i = 0; i < s.Length; i++){end = Math.Max(end, last[s[i] - 'a']);if(i == end){result.Add(end - start + 1);start = end + 1;}}return result;}
}

复杂度分析 

  • 时间复杂度:O(n),其中 n 是字符串 s 的长度。需要遍历字符串一次记录每个字母在字符串中最后一次出现的下标,然后需要遍历字符串一次计算划分结果。

  • 空间复杂度:O(∣Σ∣),其中 Σ 是字符集,这道题中 Σ 是全部小写英语字母,∣Σ∣=26。空间复杂度主要取决于哈希表,需要使用哈希表记录每个字母在字符串中最后一次出现的下标。注意返回值不计入空间复杂度。


http://www.mrgr.cn/news/41247.html

相关文章:

  • 「轻盈」之旅:OOM故障重现与解决
  • 基于单片机汽车尾灯控制系统
  • Jenkins Pipline流水线
  • 【深度学习基础模型】反卷积神经网络(Deconvolutional Networks, DN)详细理解并附实现代码。
  • 算法笔记(三)——前缀和算法
  • Java项目实战II基于Java+Spring Boot+MySQL的智能物流管理系统(源码+数据库+文档)
  • 用 Python + Selenium + Browser Driver 实现华为手机自动抢购
  • rabbitMq-----路由匹配模块
  • Acwing 简单博弈论
  • HTTP1.0和HTTP1.1有什么区别
  • postgresql-重复执行相同语句,试试 prepare!
  • 爱拼才会赢,甲骨文公司智算中心标配英伟达GPU10万颗
  • 【前沿 热点 顶会】NIPS 2024中目标检测有关的论文
  • 知识图谱入门——4:Protégé 5.6.4安装和主要功能介绍、常用插件(2024年10月2日):知识图谱构建的利器
  • Pikachu-Cross-Site Scripting-反射型xss(post)
  • JavaScript语言基础教程笔记
  • YOLO11改进|注意力机制篇|引入MLCA轻量级注意力机制
  • 【AI知识点】词频-逆文档频率(TF-IDF)
  • 在java中都是如何实现这些锁的?或者说都有哪些具体的结构实现
  • SpringBoot中的数据库查询及Mybatis和MybatisPlus的使用