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

Leetcode2414:最长的字母序连续子字符串的长度

 题目描述:

字母序连续字符串 是由字母表中连续字母组成的字符串。换句话说,字符串 "abcdefghijklmnopqrstuvwxyz" 的任意子字符串都是 字母序连续字符串 。

  • 例如,"abc" 是一个字母序连续字符串,而 "acb" 和 "za" 不是。

给你一个仅由小写英文字母组成的字符串 s ,返回其 最长 的 字母序连续子字符串 的长度。

代码思路:

  1. 初始化变量
    • left 和 right:这两个变量分别表示当前考察的连续子字符串的左右边界。初始时,left 设为 0,right 设为 1,表示从字符串的第二个字符开始向右扩展考察。
    • ans:用来记录目前找到的最长的字母序连续子字符串的长度。初始时,由于每个字符自身都可以看作是一个长度为 1 的连续子字符串,所以 ans 设为 1。
  2. 遍历字符串
    • 使用一个 while 循环遍历字符串,直到 right 达到字符串的长度。
    • 在循环内部,首先检查当前字符 s[right] 和前一个字符 s[right - 1] 是否是连续的(即 ord(s[right]) - ord(s[right - 1]) == 1)。这里 ord() 函数用于获取字符的 ASCII 值。
  3. 更新最长长度
    • 如果当前字符和前一个字符是连续的,则更新 ans 为当前考察的子字符串长度(right - left + 1)和之前记录的最长长度 ans 中的较大值。
    • 如果当前字符和前一个字符不连续,则将 left 更新为 right,表示重新开始考察一个新的连续子字符串。
  4. 移动右边界
    • 无论是否连续,每次循环都将 right 加 1,以继续向右扩展考察。
  5. 返回结果
    • 当 right 遍历完整个字符串后,返回 ans,即最长的字母序连续子字符串的长度。

代码实现:

class Solution:def longestContinuousSubstring(self, s: str) -> int:left, right = 0, 1ans = 1while right < len(s):if ord(s[right]) - ord(s[right - 1]) == 1:ans = max(ans, right - left + 1)else:left = rightright += 1return ans

http://www.lryc.cn/news/544526.html

相关文章:

  • React(12)案例前期准备
  • 2025年2月28日(RAG)
  • python-leetcode-寻找重复数
  • Vue 3 中,如果 public 目录下的 .js 文件中有一个函数执行后生成数据,并希望将这些数据传递到组件中
  • ai大模型自动化测试-TensorFlow Testing 测试模型实例
  • 初阶MySQL(两万字全面解析)
  • 数据库数据恢复—SQL Server附加数据库报错“错误 823”怎么办?
  • SpringBatch简单处理多表批量动态更新
  • 夜莺监控 - 边缘告警引擎架构详解
  • 18440二维差分
  • 安全传输,高效共享 —— 体验FileLink的跨网文件传输
  • SOME/IP 教程知识点总结
  • 学习路程八 langchin核心组件 Models补充 I/O和 Redis Cache
  • 图书数据采集:使用Python爬虫获取书籍详细信息
  • 【DeepSeek系列】05 DeepSeek核心算法改进点总结
  • 安装pointnet2-ops库
  • DO-254航空标准飞行器电机控制器设计注意事项
  • ABAP语言的动态程序
  • 开源电商项目、物联网项目、销售系统项目和社区团购项目
  • Docker教程(喂饭级!)
  • HTML:自闭合标签简单介绍
  • 【和鲸社区获奖作品】内容平台数据分析报告
  • GitCode 助力 python-office:开启 Python 自动化办公新生态
  • 超参数、网格搜索
  • or-tools编译命令自用备注
  • vulnhub靶场【kioptrix-4】靶机
  • readline模块详解!!【Node.js】
  • 软件测试的七大误区
  • 【欢迎来到Git世界】Github入门
  • 解决 Ubuntu 24.04 虚拟机内无法ping 通 Hostname 的问题