[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];
    }
}
相关推荐
_深海凉_2 小时前
LeetCode热题100-88. 合并两个有序数组
算法·leetcode·职场和发展
Hui_AI7202 小时前
保险条款NLP解析与知识图谱搭建:让AI准确理解保险产品的技术方案
开发语言·人工智能·python·算法·自然语言处理·开源·开源软件
人道领域2 小时前
【LeetCode刷题日记】119.最长连续序列(字节面试题最新)
java·算法·leetcode·面试·职场和发展
spssau2 小时前
非量表问卷信效度分析,用内容效度 + 重测信度评估数据质量
人工智能·算法·机器学习
我不是懒洋洋2 小时前
【数据结构】二叉树-堆(树的概念、二叉树的概念、顺序结构的结构及实现、堆的实现、堆排序、TopK问题)
c语言·数据结构·c++·经验分享·算法·青少年编程
KobeSacre2 小时前
将有序数组转换为二叉搜索树
数据结构·算法·leetcode
脱氧核糖核酸__2 小时前
LeetCode热题100——160.相交链表(两种解法)
算法·leetcode·链表
碧海银沙音频科技研究院2 小时前
博通BK7258原生语音识别与dump功能功能实现
人工智能·深度学习·算法