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

代码随想录算法训练营第四十六天|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.kler.cn/a/145158.html

相关文章:

  • 团体程序设计天梯赛-练习集——L1-028 判断素数
  • 【Block总结】PConv,部分卷积|即插即用
  • C++ 堆栈分配的区别
  • Ansible自动化运维实战--fetch、cron和group模块(5/8)
  • 【16届蓝桥杯寒假刷题营】第2期DAY4
  • .NET MAUI进行UDP通信(二)
  • 电子学会C/C++编程等级考试2023年03月(二级)真题解析
  • Qt 软件调试(二)使用dump捕获崩溃信息
  • Linux | 重定向 | 文件概念 | 查看文件 | 查看时间 | 查找文件 | zip
  • 基于Python的面向对象分类实例Ⅱ
  • LeetCode Hot100 33.搜索旋转排序数组
  • 【精选必看】MyBatis映射文件及动态SQL,一级,二级缓存介绍
  • 【广州华锐互动】Web3D云展编辑器能为展览行业带来哪些便利?
  • [Python人工智能] 四十.命名实体识别 (1)基于BiLSTM-CRF的威胁情报实体识别万字详解
  • Swagger在php和java项目中的应用
  • CentOS rpm安装Nginx和配置
  • FFmpeg常用命令讲解及实战二
  • 【Spring篇】spring核心——AOP面向切面编程
  • 鸿蒙原生应用/元服务开发-AGC分发如何上架HarmonyOS应用
  • openssl升级
  • JVM虚拟机:JVM调优第一步,了解JVM常用命令行参数
  • JsonRPC协议详解(协议介绍、请求示例、响应示例)
  • kafka学习笔记(一)--脑裂
  • 【statsmodels】快速实现回归预测
  • 【代码随想录】算法训练计划31
  • Docker ps命令