代码随想录算法训练营第四十六天|139.单词拆分

139.单词拆分

https://leetcode.com/problems/word-break/description/

思路:判断一个字符串是否能由列表中的子字符串组成, 列表中的元素可以复用, 那么可以把这类问题转化成完全背包问题。 用 dp 数组的i+1记录到字符串的下标 i 是是否可以组成。 dp0 要初始化成 1. 然后考虑到这个问题是排列问题, 例如 字符串'leetcode' 列表'code', 'leet'. 所以应该先循环背包容量再循环数组。 如果 stri-len(substr) :i == substr, 并且 dpi-len(substr) 都是true 的时候, dpi = True. 或者 如果原本 dpi = True了, 就不要再往下循环数组了 (表示已经fit了)。

难点:递归的逻辑比较难想, 要考虑原本dpi = True 的情况

python 复制代码
class Solution:
    def wordBreak(self, s: str, wordDict: List[str]) -> bool:
        dp = [0 for _ in range(len(s)+1)]
        dp[0] = 1
        words = [(word, len(word)) for word in wordDict]
        for i in range(1, len(dp)):
            for word, l in words:
                if i < l: continue
                dp[i] = int(word == s[i-l:i]) * dp[i-l]
                if dp[i] == 1: break
        return bool(dp[-1])
        
相关推荐
叫我:松哥20 分钟前
基于Python flask的中学可控智能命题系统设计与实现,整合遗传算法、DeepSeek 大模型及数据库技术构建一体化应用
数据库·人工智能·python·算法·机器学习·flask·遗传算法
黎阳之光32 分钟前
黎阳之光透明大楼:实景孪生重构智慧建筑全新范式
人工智能·物联网·算法·安全·数字孪生
旖-旎2 小时前
《LeetCode 130 被围绕的区域 FloodFill DFS 解法》
c++·算法·深度优先·力扣·floodfill
林森lsjs2 小时前
斐波那契数列的 N 种解法:从递归到动态规划的优化之路【算法思考】
算法·动态规划
apcipot_rain3 小时前
计科八股20260616(1)——堆存中位数、链表判环、黑白测试、敏捷开发与瀑布模型、配置管理、持续集成、池化
数据结构·算法·软件工程
JAVA面经实录9179 小时前
Java 数据结构与算法 (终极完整学习文档)
java·数据结构·算法
开源Z11 小时前
LeetCode 42 · 接雨水:从暴力到双指针的三步优化
算法·leetcode
旖-旎11 小时前
《LeetCode 695 岛屿的最大面积 FloodFill DFS 解法》
c++·算法·力扣·深度优先遍历·floodfill
syagain_zsx11 小时前
STL 之 vector 讲练结合
c++·算法