【算法四十五】139. 单词拆分

139. 单词拆分

动态规划:

java 复制代码
class Solution {
    public boolean wordBreak(String s, List<String> wordDict) {
        //子问题:字符串的前 i 个字符能否用字典里的单词拼接
        //状态转移方程:dp[i] = true  if ∃ j ∈ [0, i) , dp[j] == true && s[j..i-1] ∈ wordDict
        //dp[i] = false 
        //方向:从前到后
        int n = s.length();
        int maxLen = 0;
        for(String word:wordDict){
            maxLen = Math.max(maxLen,word.length());
        }
        //转化为Set是因为set的contains方法时间复杂度是O(1),List是O(n)
        Set<String> wordDicts = new HashSet<>(wordDict);

        boolean[] dp = new boolean[n+1];
        dp[0] = true;

        //枚举前i个字符
        for(int i = 1;i<=n;i++){
            //枚举可划分的下标
            for(int j = Math.max(0,i-maxLen);j<i;j++){
                if(dp[j] && wordDicts.contains(s.substring(j,i))){
                    dp[i] = true;
                    break;
                }
            }
        }
        return dp[n];
    }
}

时间复杂度:O(N*M),N是字符串长度,S是最长单词长度

空间复杂度:O(N)

相关推荐
玖釉-23 分钟前
编辑距离(Edit Distance)——从字符串相似度到动态规划经典模型
算法·leetcode·动态规划
c2385636 分钟前
c/c++中的二叉树进阶
c语言·c++·算法
吴可可1231 小时前
Win7下C#开发AutoCAD首选版本
算法
Halo_tjn1 小时前
反射与设计模式2
java·开发语言·算法
_日拱一卒1 小时前
LeetCode:46全排列
算法·leetcode·职场和发展
剑挑星河月2 小时前
31.下一个排列
java·算法·leetcode
凌波粒2 小时前
LeetCode--98.验证二叉搜索树(二叉树)
算法·leetcode·职场和发展
Kurisu5752 小时前
深度拆解:从令牌桶到滑动窗口,高并发系统限流算法的数学本质与边界
java·网络·算法
哈泽尔都2 小时前
运动控制教学——5分钟学会力控算法(阻抗/导纳/力位混合)
c++·python·算法·决策树·贪心算法·机器人·gpu算力
WWW65262 小时前
代码随想录 打卡第四十七天
数据结构·算法·leetcode