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

相关推荐
洛水水2 小时前
【力扣100题】32.将有序数组转换为二叉搜索树
数据结构·算法·leetcode
如竟没有火炬3 小时前
用队列实现栈
开发语言·数据结构·python·算法·leetcode·深度优先
云栖梦泽在3 小时前
AI安全入门:AI模型泄露的风险与防护措施
人工智能·算法·动态规划
水木流年追梦4 小时前
大模型入门-应用篇3-Agent智能体
开发语言·python·算法·leetcode·正则表达式
洛水水4 小时前
【力扣100题】31.二叉树的层序遍历
算法·leetcode·职场和发展
君义_noip4 小时前
CSP-S 2025 入门级 第一轮(初赛) 完善程序(1)
c++·算法·信息学奥赛·初赛·csp 第一轮
洛水水4 小时前
【力扣100题】41.爬楼梯
算法·leetcode·职场和发展
sheeta19985 小时前
LeetCode 每日一题笔记 日期:2026.05.13 题目:1674. 使数组互补的最少操作次数
笔记·算法·leetcode
liulilittle6 小时前
TCP UCP v1.0:BBR 的非破坏性约束层
网络·c++·网络协议·tcp/ip·算法·c·通信