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

Leetcode 3557. Find Maximum Number of Non Intersecting Substrings

  • Leetcode 3557. Find Maximum Number of Non Intersecting Substrings
    • 1. 解题思路
    • 2. 代码实现
  • 题目链接:3557. Find Maximum Number of Non Intersecting Substrings

1. 解题思路

这一题就是一个比较直接的动态规划的题目,我们只需要考察每一个位是否可以作为一个子串的开头,如果可以那么比较其被取用以及不被取用时的较大值将其进行返回,如果不可以,那么直接返回其不被取用时的值即可。

2. 代码实现

给出python代码实现如下:

class Solution:def maxSubstrings(self, word: str) -> int:n = len(word)locs = defaultdict(list)for i, ch in enumerate(word):locs[ch].append(i)@lru_cache(None)def dp(idx):if idx >= n:return 0ch = word[idx]i = bisect.bisect_left(locs[ch], idx+3)if i >= len(locs[ch]):return dp(idx+1)else:return max(dp(idx+1), 1 + dp(locs[ch][i] + 1))return dp(0)

提交代码评测得到:耗时1713ms,占用内存420.2MB。

http://www.xdnf.cn/news/656533.html

相关文章:

  • OpenGL: Transform知识
  • 8.1.2 商品信息动态网站 - JSP+Servlet实现动态网站
  • 基于DDD的企业团餐订餐平台微服务架构设计与实现
  • 使用 Cannonballs 进行实用导体粗糙度建模
  • IP动态伪装开关
  • C#实现SSE通信方式的MCP Server
  • 十三: 神经网络的学习
  • 集星云推短视频矩阵系统的定制化与私有化部署方案
  • 将YOLO格式的数据集转换为mmdetection格式
  • 【密码学——基础理论与应用】李子臣编著 第十三章 数字签名 课后习题
  • 数据保护在Web3应用中的重要性及其实现
  • vue+ThreeJs 创建过渡圆圈效果
  • 行为型:状态模式
  • SmartSoftHelp 图片资源技术保护可执行添加水印方案---深度优化版:SmartSoftHelp DeepCore XSuite
  • 【FAQ】HarmonyOS SDK 闭源开放能力 —Account Kit(4)
  • 第二十章:数据治理之数据指标(二):数据指标和数据指标体系
  • 日语学习-日语知识点小记-构建基础-JLPT-N4阶段(29):ので
  • “轩辕杯“云盾砺剑CTF挑战赛 Web wp
  • 限流系列:sentinel
  • 哈希表基础知识
  • 选择SEO公司时需要注意哪些关键指标?
  • 多模态大语言模型arxiv论文略读(九十二)
  • 2025.05.26【Wordcloud】词云图绘制技巧
  • pkg-config的功能与作用说明
  • jeecg-boot vue点击左侧菜单跳转无菜单栏的全屏页面
  • PostgreSQL日志管理完整方案(AI)
  • 学习心得(14--16)
  • 使用 Vuex 实现用户注册与登录功能
  • HTML流星雨
  • 充电枪IEC62196/EN 62196测试内容