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

题目链接

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

思路

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

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

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

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

如果能找到切点且当前位置也合法,那么就说明当前位置可以作为一个切点,因此dp[i] = 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];
    }
}
相关推荐
Dlrb121115 小时前
C语言-指针数组与数组指针
c语言·数据结构·算法·指针·数组指针·指针数组·二级指针
WL_Aurora15 小时前
Python 算法基础篇之集合
python·算法
平行侠16 小时前
A15 工业路由器IP前缀高速检索与内存压缩系统
网络·tcp/ip·算法
阿旭超级学得完17 小时前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表
li星野17 小时前
位运算 & 数学 & 高频进阶九题通关(Python + C++)
c++·python·学习·算法
jerryinwuhan17 小时前
hello算法,简单讲(1)
算法·排序算法
y = xⁿ17 小时前
20天速通LeetCodeday15:BFS广度优先搜索
算法·宽度优先
400分17 小时前
吃透RAG核心-----语义检索与关键字检索底层原理
算法·架构
目黑live +wacyltd17 小时前
算法备案:常见驳回原因与应对策略
人工智能·算法
磊 子18 小时前
多态类原理+四种类型转换+异常处理
开发语言·c++·算法