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

【算法四十五】139. 单词拆分

139. 单词拆分

动态规划:

class Solution { public boolean wordBreak(String s, List<String> wordDict) { //子问题:字符串的前 i 个字符能否用字典里的单词拼接 //状态转移方程:dp[i] = true if ∃ j ∈ [0, i) , dp[j] == true && s[j..i-1] ∈ wordDict //dp[i] = false //方向:从前到后 int n = s.length(); int maxLen = 0; for(String word:wordDict){ maxLen = Math.max(maxLen,word.length()); } //转化为Set是因为set的contains方法时间复杂度是O(1),List是O(n) Set<String> wordDicts = new HashSet<>(wordDict); boolean[] dp = new boolean[n+1]; dp[0] = true; //枚举前i个字符 for(int i = 1;i<=n;i++){ //枚举可划分的下标 for(int j = Math.max(0,i-maxLen);j<i;j++){ if(dp[j] && wordDicts.contains(s.substring(j,i))){ dp[i] = true; break; } } } return dp[n]; } }

时间复杂度:O(N*M),N是字符串长度,S是最长单词长度

空间复杂度:O(N)

http://www.jsqmd.com/news/799880/

相关文章:

  • 水下折射相机标定与三维重建算法【附代码】
  • grok2api项目实战:构建OpenAI兼容层,无缝集成非标准大模型API
  • KMP算法核心:从暴力匹配到‘记忆’跳转的演进之路
  • 奇异值分解(SVD):从黑盒到语义空间的一场解剖之旅
  • 2025届必备的六大AI辅助写作工具推荐
  • 从定义到迭代:Welford算法如何重塑标准差的计算体验
  • PC市场转型:从性能竞赛到价值回归的产业变革
  • LLM、Agent、Skills、MCP:AI开发必懂四大概念,一张图全搞懂!
  • OpenClaw 与 钉钉机器人 高效对接指南
  • 2026年4月目前技术好的同步带轮厂商口碑推荐,橡胶同步带/齿轮/同步带/同步轮/同步带轮,同步带轮厂商口碑推荐 - 品牌推荐师
  • NHTSA强制AEB/PAEB新规:汽车安全技术从辅助预警到主动干预的深度变革
  • 告别裸奔MCU!手把手教你用OSAL调度器给STM32项目搭个轻量级框架
  • ARMulator指令集模拟器开发与调试指南
  • PS4游戏存档管理终极指南:如何使用Apollo工具轻松备份和修改游戏进度
  • 从数学证明到代码:LeanDojo如何用机器学习自动化定理证明
  • 无人驾驶-数据集01:NAVSIM: Data-Driven Non-Reactive Autonomous Vehicle Simulation and Benchmarking
  • 企业如何高效破局?明星代言公司的核心痛点与解决方案 - 品牌策略师
  • 从AMD ARM合资案看半导体技术路线、生态与战略抉择
  • 本地AI文档分析系统DocMind AI:架构、部署与实战指南
  • 本地AI文档分析系统DocMind AI:架构、部署与实战指南
  • 如何快速转换B站缓存视频:m4s-converter完整指南
  • 爆火5.3k!上海交大开源《动手学大模型》,带你从零吃透
  • AI工具全景图:从概念到实战,构建个性化生产力工作流
  • 从CTFHub的SSRF靶场实战,聊聊Gopher协议打内网的那些“坑”与编码细节
  • 告别拥堵:用强化学习PressLight算法,手把手教你搭建干线交通信号协调系统
  • 告别拥堵:用强化学习PressLight算法,手把手教你搭建干线交通信号协调系统
  • 架构演进:告别“伪多开”,基于内置原生指纹内核的跨平台店群RPA基建
  • 从论文到博客:手把手教你用Markdown+MathJax搞定复杂数学公式(含常见错误排查)
  • 从零到一:手把手教你搞定复杂截面形心与惯性矩计算
  • TaskWing开源任务管理后端:自部署、API-First架构与全栈实践指南