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

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

相关文章

linux生产者,消费者问题

pthread_cond_wait() :用于阻塞当前线程,等待别的线程使用pthread_cond_signal()或pthread_cond_broadcast来唤醒它。 pthread_cond_wait() 必须与pthread_mutex 配套使用。pthread_cond_wait()函数一进入wait状态就会自动release mutex。当其他线程通过pthread

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

2024.6.24 IDEA中文乱码问题(服务器 控制台 TOMcat)实测已解决

1.问题产生原因: 1.文件编码不一致:如果文件的编码方式与IDEA设置的编码方式不一致,就会产生乱码。确保文件和IDEA使用相同的编码,通常是UTF-8。2.IDEA设置问题:检查IDEA的全局编码设置和项目编码设置是否正确。3.终端或控制台编码问题:如果你在终端或控制台看到乱码,可能是终端的编码设置问题。确保终端使用的是支持你的文件的编码方式。 2.解决方案: 1.File -> S

vcpkg安装opencv中的特殊问题记录(无法找到opencv_corexd.dll)

我是按照网上的vcpkg安装opencv方法进行的(比如这篇:从0开始在visual studio上安装opencv(超详细,针对小白)),但是中间出现了一些别人没有遇到的问题,虽然原因没有找到,但是本人给出一些暂时的解决办法: 问题1: 我在安装库命令行使用的是 .\vcpkg.exe install opencv 我的电脑是x64,vcpkg在这条命令后默认下载的也是opencv2:x6

大语言模型(LLMs)能够进行推理和规划吗?

大语言模型(LLMs),基本上是经过强化训练的 n-gram 模型,它们在网络规模的语言语料库(实际上,可以说是我们文明的知识库)上进行了训练,展现出了一种超乎预期的语言行为,引发了我们的广泛关注。从训练和操作的角度来看,LLMs 可以被认为是一种巨大的、非真实的记忆库,相当于为我们所有人提供了一个外部的系统 1(见图 1)。然而,它们表面上的多功能性让许多研究者好奇,这些模型是否也能在通常需要系

问题-windows-VPN不正确关闭导致网页打不开

为什么会发生这类事情呢? 主要原因是关机之前vpn没有关掉导致的。 至于为什么没关掉vpn会导致网页打不开,我猜测是因为vpn建立的链接没被更改。 正确关掉vpn的时候,会把ip链接断掉,如果你不正确关掉,ip链接没有断掉,此时你vpn又是没启动的,没有域名解析,所以就打不开网站。 你可以在打不开网页的时候,把vpn打开,你会发现网络又可以登录了。 方法一 注意:方法一虽然方便,但是可能会有

vue同页面多路由懒加载-及可能存在问题的解决方式

先上图,再解释 图一是多路由页面,图二是路由文件。从图一可以看出每个router-view对应的name都不一样。从图二可以看出层路由对应的组件加载方式要跟图一中的name相对应,并且图二的路由层在跟图一对应的页面中要加上components层,多一个s结尾,里面的的方法名就是图一路由的name值,里面还可以照样用懒加载的方式。 页面上其他的路由在路由文件中也跟图二是一样的写法。 附送可能存在

vue+elementui分页输入框回车与页面中@keyup.enter事件冲突解决

解决这个问题的思路只要判断事件源是哪个就好。el分页的回车触发事件是在按下时,抬起并不会再触发。而keyup.enter事件是在抬起时触发。 so,找不到分页的回车事件那就拿keyup.enter事件搞事情。只要判断这个抬起事件的$event中的锚点样式判断不等于分页特有的样式就可以了 @keyup.enter="allKeyup($event)" //页面上的//js中allKeyup(e

vue+elementui--$message提示框被dialog遮罩层挡住问题解决

最近碰到一个先执行this.$message提示内容,然后接着弹出dialog带遮罩层弹框。那么问题来了,message提示框会默认被dialog遮罩层挡住,现在就是要解决这个问题。 由于都是弹框,问题肯定是出在z-index比重问题。由于用$message方式是写在js中而不是写在html中所以不是很好直接去改样式。 不过好在message组件中提供了customClass 属性,我们可以利用

Visual Studio中,MSBUild版本问题

假如项目规定了MSBUild版本,那么在安装完Visual Studio后,假如带的MSBUild版本与项目要求的版本不符合要求,那么可以把需要的MSBUild添加到系统中,然后即可使用。步骤如下:            假如项目需要使用V12的MSBUild,而安装的Visual Studio带的MSBUild版本为V14。 ①到MSDN下载V12 MSBUild包,把V12包解压到目录(