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

力扣-动态规划-139 单词拆分

思路

  1. dp数组定义:用wordDict数组可以完成不超过j的字符串的可能为dp[j]
  2. 递推公式:
    tmp = s.substr(j - wordDict[i].size(), wordDict[i].size());
    dp[j] = (dp[j - wordDict[i].size()] && wordDict[i] == tmp) || dp[j];
  3. dp数组初始化:dp[0] = true;
  4. 遍历顺序:由于算是排列问题,不同字典语句先后会影响判断,所以先遍历背包再遍历物品,当前容量在前一个容量完成了对所有物品遍历一遍
  5. 时间复杂度:O(n*m)     

代码

class Solution {
public:bool wordBreak(string s, vector<string>& wordDict) {vector<bool> dp(s.size() + 1, false);dp[0] = true;for (int j = 1; j <= s.size(); j++) {for (int i = 0; i < wordDict.size(); i++) {if (j >= wordDict[i].size()) {string tmp;tmp = s.substr(j - wordDict[i].size(), wordDict[i].size());dp[j] = (dp[j - wordDict[i].size()] && wordDict[i] == tmp) || dp[j];}}}return dp[s.size()];}
};

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

相关文章:

  • 建筑能耗监测系统数据采集装置 物联网网关功能参数介绍
  • vue深拷贝:1、使用JSON.parse()和JSON.stringify();2、使用Lodash库;3、使用深拷贝函数(采用递归的方式)
  • ES 删除index 的curl
  • 游戏引擎学习第124天
  • 第十四届蓝桥杯Scratch11月stema选拔赛真题——小猫照镜子
  • 使用vscode导出Markdown的PDF无法显示数学公式的问题
  • 前端系列之:Blob
  • 【项目管理】基于 C 语言的 QQ 聊天室实现(TCP + 多线程 + SQLite3)
  • Apache Flink:实时数据流处理的终极武器
  • 点云处理入门--PointNetPointNet++论文与代码详解
  • 通过Nginx负载均衡+Keepalived实现业务高可用
  • Spark技术系列(三):Spark算子全解析——从基础使用到高阶优化
  • ES6模块化详解:导入与导出方式
  • 每日学习Java之一万个为什么?[MySQL面试篇]
  • 常用空间数据结构对比
  • AnythingLLM+LM Studio本地知识库构建
  • 使用 Java 更新 Word 文档中的图表数据-超详细
  • Qt常用控件之下拉框QComboBox
  • Qt 中集成mqtt协议
  • 2024年第十五届蓝桥杯大赛软件赛省赛Python大学A组真题解析
  • AI大模型-提示工程学习笔记19-自我反思
  • GaussDB 学习实战指南:从部署到高并发优化的全流程解析
  • vue3 Props的使用
  • Ecode前后端传值
  • 【Linux】进程状态(二)
  • domain 网络安全 网络安全域
  • 链表和STL —— list 【复习笔记】
  • Java Map实现类面试题
  • 技术架构和工程架构区别
  • 简单介绍JVM