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

代码随想录算法训练营第四十五天|139.单词拆分、背包问题总结

LeetCode 139. 单词拆分
题目链接:139. 单词拆分 - 力扣(LeetCode)

这道题使用完全背包来实现,我们首先考虑字符串是否可以由字符串列表组成,因此dp数组大小为n + 1 ,其意义是,在n个位置时是否能拼接成功。因此,当前n状态由前面状态所转移确定。

每道题都要考虑dp五步:

1)确定dp数组下标与值的关系:处于n位时是否能拼接成功。

2)确定递推公式:我们把n个数的状态,看作i之前j到i的字母是否能在字符串列表中存在

3)确定初始值:dp[0]为1,没得选

4)确定遍历的数:注意一下边界问题

5)带入验证一下

代码:

#python //一维DP
class Solution:def wordBreak(self, s: str, wordDict: List[str]) -> bool:n = len(s)dp = [0 for _ in range(n + 1)]dp[0] = 1  //由空集可以组成for i in range(1, n + 1):for j in range(i + 1): //注意i与j的位置来确定在字符串中子串的边界,从而来判断是否在列表中if dp[j] == 1 and str(s[j : i]) in wordDict:dp[i] = 1   //满足return bool(dp[n])  //返回布尔值

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

相关文章:

  • 深度学习卫星遥感图像检测与识别 -opencv python 目标检测 计算机竞赛
  • wxWidgets 3.2.4发布 —— 发布于2023年11月11日
  • PyQt6运行QTDesigner生成的ui文件程序
  • 基于mediapipe的人手21点姿态检测模型—CPU上检测速度惊人
  • 系统架构设计: 21 论敏捷软件开发方法及其应用
  • 【深度学习】脸部修复,CodeFormer,论文,实战
  • OpenGL_Learn14(光照贴图)
  • 【JVM精讲与GC调优教程(概述)】
  • 蓝桥杯物联网竞赛_STM32L071_2_继电器控制
  • python之pyqt专栏2-项目文件解析
  • Kafka 集群如何实现数据同步
  • opencv- CLAHE 有限对比适应性直方图均衡化
  • IOS免签封装打包苹果APP的方法
  • Springboot引入分布式搜索引擎Es RestAPI
  • Lua脚本解决redis实现的分布式锁多条命令原子性问题
  • Vatee万腾独特科技力量的前沿探索:Vatee的数字化奇点
  • C++面试,const的使用
  • 小总结----长度
  • 【深度学习】如何选择神经网络的超参数
  • jQuery 3.0 新增了哪些特性?(jQuery 3 所引入的那些最重要的变化)
  • MindStudio学习一 整体介绍
  • excel表中慎用合并单元格,多用跨列居中
  • linux网络编程之UDP编程
  • YB4556 28V、1A、单节、线性锂电池充电IC
  • 基于单片机设计的大气气压检测装置(STC89C52+BMP180实现)
  • 【ChatGLM3-6B】Docker下部署及微调
  • 编程常见报错信息及解决方案汇总
  • 从Redis反序列化UserDetails对象异常后发现FastJson序列化的一些问题
  • 0001Java程序设计-springboot基于微信小程序批发零售业商品管理系统
  • 中国防锈油市场深度调研与投资战略报告(2023版)