本文介绍: 这道题使用完全背包来实现,我们首先考虑字符串是否可以由字符串列表组成,因此dp数组大小为n + 1 ,其意义是,在n个位置时是否能拼接成功。因此,当前n状态由前面状态所转移确定。2)确定递推公式:我们把n个数的状态,看作i之前j到i的字母是否能在字符串列表中存在。1)确定dp数组下标与值的关系:处于n位时是否能拼接成功。3)确定初始值:dp[0]为1,没得选。LeetCode 139. 单词拆分。4)确定遍历的数:注意一下边界问题。
LeetCode 139. 单词拆分
题目链接:139. 单词拆分 – 力扣(LeetCode)
这道题使用完全背包来实现,我们首先考虑字符串是否可以由字符串列表组成,因此dp数组大小为n + 1 ,其意义是,在n个位置时是否能拼接成功。因此,当前n状态由前面状态所转移确定。
每道题都要考虑dp五步:
2)确定递推公式:我们把n个数的状态,看作i之前j到i的字母是否能在字符串列表中存在
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]) //返回布尔值
原文地址:https://blog.csdn.net/alimamaalala/article/details/134611991
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_6337.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。