[HOT 100]今日一练------单词拆分

题目链接

https://leetcode.cn/problems/word-break/?envType=study-plan-v2&envId=top-100-liked

思路

动态规划,dpi表示前i个位置是否可以被正常划分

初始化的话我们只需要把dp0 = true,因为空字符串天然不需要划分

关于动态规划部分,我们主要是需要考虑:

  1. 前面的位置是否可以正常划分,即要找到前面的分割点
  2. 切割点到当前位置即最后一刀这个位置是否合法

如果能找到切点且当前位置也合法,那么就说明当前位置可以作为一个切点,因此dpi = true

代码

java 复制代码
class Solution {
    //动态规划: dp[i]表示前i个字符是否可以被成功划分
    public boolean wordBreak(String s, List<String> wordDict) {
        HashSet<String> set = new HashSet<>(wordDict);
        int n = s.length();
        boolean[] dp = new boolean[n + 1];
        dp[0] = true;
        for(int i = 1; i <= n; i++)
            for(int j = 0; j <= i; j++) {
                //前j个字符可以找到切点且最后一刀分割出来的字符串也在字典里,即合法
                if(dp[j] && set.contains(s.substring(j, i))) {
                    dp[i] = true;
                    break;
                }
            }
        return dp[n];
    }
}
相关推荐
小欣加油13 分钟前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
lqqjuly22 分钟前
前沿算法深度解析(二)
人工智能·算法·机器学习
徐小夕2 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei2 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
Hello:CodeWorld3 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi84 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang5 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby5 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠6 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力7 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试