【算法四十五】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)

相关推荐
To_OC4 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户938515635079 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC10 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥11 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者12 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者13 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月15 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星16 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星16 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试