「动态规划」如何解决单词拆分问题?

2024-06-23 20:52

本文主要是介绍「动态规划」如何解决单词拆分问题?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

139. 单词拆分icon-default.png?t=N7T8https://leetcode.cn/problems/word-break/description/

给你一个字符串s和一个字符串列表wordDict作为字典。如果可以利用字典中出现的一个或多个单词拼接出s则返回true。注意:不要求字典中出现的单词全部都使用,并且字典中的单词可以重复使用。

  1. 输入:s = "leetcode",wordDict = ["leet", "code"],输出:true,解释:返回true因为"leetcode"可以由"leet"和"code"拼接成。
  2. 输入:s = "applepenapple",wordDict = ["apple", "pen"],输出:true,解释:返回true因为"applepenapple"可以由"apple" "pen" "apple"拼接成。注意,你可以重复使用字典中的单词。
  3. 输入:s = "catsandog":wordDict = ["cats", "dog", "sand", "and", "cat"],输出:false。

提示:1 <= s.length <= 300,1 <= wordDict.length <= 1000,1 <= wordDict[i].length <= 20,s和wordDict[i]仅由小写英文字母组成,wordDict中的所有字符串互不相同。


我们用动态规划的思想来解决这个问题。

确定状态表示:根据经验和题目要求,我们用dp[i]表示:以i位置为结尾的子串,能否被字典中的单词拼接

推导状态转移方程:如果以i位置为结尾的子串可以被字典中的单词拼接,那么一定分为前半部分和后半部分,后半部分是一个单词。我们用j遍历[0, i]的范围,如果有至少1个j同时满足:

  1. dp[j - 1] == true,即以j - 1位置为结尾的子串可以被拼接
  2. s的下标范围在[j, i]的子串在字典中

则dp[i] = true。如果没有1个j同时满足这2个条件,那么dp[i] = false

但是由于j的范围是[0, i],当j = 0时,j - 1 = -1,判断dp[j - 1]时会越界,我们需要处理一下。显然,当j = 0时,表示前半部分不存在,后半部分是子串的整体,此时只需判断条件2是否满足

初始化:根据状态转移方程,填dp表时不存在越界问题,不需要初始化

填表顺序:根据状态转移方程,显然应从左往右填表

返回值:根据状态表示,应返回dp[n - 1],其中n为字符串s的长度。

细节问题:dp表的规模和字符串s相同,均为1 x n。为了方便查找子串是否在字典中,可以先把字典中的所有字符串存储到哈希表中。

class Solution {
public:bool wordBreak(string s, vector<string>& wordDict) {int n = s.size();unordered_set hash(wordDict.begin(), wordDict.end());// 创建dp表vector<bool> dp(n);// 填表for (int i = 0; i < n; i++) {for (int j = i; j >= 0; j--) {if ((j == 0 || dp[j - 1]) &&hash.count(s.substr(j, i - j + 1))) {dp[i] = true;break;}}}return dp[n - 1];}
};

这篇关于「动态规划」如何解决单词拆分问题?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1088245

相关文章

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

nginx中端口无权限的问题解决

《nginx中端口无权限的问题解决》当Nginx日志报错bind()to80failed(13:Permissiondenied)时,这通常是由于权限不足导致Nginx无法绑定到80端口,下面就来... 目录一、问题原因分析二、解决方案1. 以 root 权限运行 Nginx(不推荐)2. 为 Nginx

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

一文详解SpringBoot中控制器的动态注册与卸载

《一文详解SpringBoot中控制器的动态注册与卸载》在项目开发中,通过动态注册和卸载控制器功能,可以根据业务场景和项目需要实现功能的动态增加、删除,提高系统的灵活性和可扩展性,下面我们就来看看Sp... 目录项目结构1. 创建 Spring Boot 启动类2. 创建一个测试控制器3. 创建动态控制器注

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S