2025年- H83-Lc191--139.单词拆分(动态规划)--Java版

1.题目描述

2.思路

字符串s是一个容器(一个背包),wordDict词典是物品,这里面的每个物品我们可以使用多次。

动归五部曲

(1)字符串的长度为i,dp[i]=true。

dp[s.size]

dp[0]=代表空字符串

(2)对于装满物品的背包是有顺序要求的。所以就是求排列数,我们需要先遍历背包再遍历物品。

(3)

1)状态定义

dp[i] 表示 前 i 个字符(即下标 0 ~ i‑1 的子串)能否被字典单词完全拆分。

dp[0] = true:空串视为可拆分的起点。

2)状态转移

对每个终点 i (1 ... n),枚举所有可能的切分点 j (0 ... i‑1)


3.代码实现

java 复制代码
class Solution {
    public boolean wordBreak(String s, List<String> wordDict) {
         
        //创建set集合保留不重复的词典元素。
         // 1. 把词典放进 HashSet,O(1) 时间判断是否存在
        Set<String> wordDictSet=new HashSet<>(wordDict);
        //创建s.length()+1的数组长度,默认dp[0]是存储空字符串,其他元素代表的是false
      // 2. dp[i] 表示 s 的前 i 个字符能否被拆分
        boolean[] dp=new boolean[s.length()+1];
        dp[0]=true;//代表空字符串
         // 空串一定可拆分
        //因为字符串的先后顺序对拼接是有影响的,所以用排列,先遍历背包再遍历物品
        for(int i=1;i<=s.length();i++)//背包,i从1开始,i=0的时候代表的是空字符串
        {// 4. 内层遍历"物品" j = 0 ... i-1(尝试最后一个单词的起点)
         for(int j=0;j<i;j++)
         {
            //首先遍历的dp[j]的子串是存在的
              // 5. 如果前 j 个字符可拆分,且 s[j...i-1] 在字典中
            if(dp[j]==true&&wordDictSet.contains(s.substring(j,i)))
            {
                 前 i 个字符可拆分
                dp[i]=true;
                break;
            }
         }
        }
           // 6. 返回整串能否拆分
           return dp[s.length()];
    }
}
相关推荐
机器学习之心2 小时前
多目标鲸鱼优化算法(NSWOA),含46种测试函数和9个评价指标,MATLAB实现
算法·matlab·多目标鲸鱼优化算法·46种测试函数·9个评价指标
max5006003 小时前
基于Meta Llama的二语习得学习者行为预测计算模型
人工智能·算法·机器学习·分类·数据挖掘·llama
callJJ3 小时前
从 0 开始理解 Spring 的核心思想 —— IoC 和 DI(2)
java·开发语言·后端·spring·ioc·di
wangjialelele3 小时前
Linux中的线程
java·linux·jvm·c++
谷咕咕3 小时前
windows下python3,LLaMA-Factory部署以及微调大模型,ollama运行对话,开放api,java,springboot项目调用
java·windows·语言模型·llama
没有bug.的程序员4 小时前
MVCC(多版本并发控制):InnoDB 高并发的核心技术
java·大数据·数据库·mysql·mvcc
在下村刘湘4 小时前
maven pom文件中<dependencyManagement><dependencies><dependency> 三者的区别
java·maven
王哥儿聊AI4 小时前
Lynx:新一代个性化视频生成模型,单图即可生成视频,重新定义身份一致性与视觉质量
人工智能·算法·安全·机器学习·音视频·软件工程
不务专业的程序员--阿飞5 小时前
JVM无法分配内存
java·jvm·spring boot
李昊哲小课5 小时前
Maven 完整教程
java·maven