day39|139.单词拆分 背包问题ending
创始人
2024-05-28 16:30:08

139.单词拆分

给你一个字符串 s 和一个字符串列表 wordDict 作为字典。请你判断是否可以利用字典中出现的单词拼接出 s 。

注意:不要求字典中出现的单词全部都使用,并且字典中的单词可以重复使用。

示例 1:

输入: s = "leetcode", wordDict = ["leet", "code"]

输出: true

解释: 返回 true 因为 "leetcode" 可以由 "leet" 和 "code" 拼接成。

示例 2:

输入: s = "applepenapple", wordDict = ["apple", "pen"]

输出: true

解释:返回 true
因为 "applepenapple"可以由 "apple" "pen" "apple" 拼接成。

注意,你可以重复使用字典中的单词。

示例 3:

输入: s = "catsandog", wordDict = ["cats", "dog", "sand", "and", "cat"]

输出: false

问题分析: 

1、确定dp数组以及下标的含义

dp[j]:拆分字符串的长度为j,dp[j]=true表示可以拆分为一个或多个字典中出现的单词。

2、确定递推公式

完全背包,重复利用物品,且为排列数

字符串为背包,单词为物品,截字符串(j-len,j)看是否是一个单词,并且他的前序子串也是一个或多个单词,也就是判断是否为true

所以递推公式为:

if(j>=len&&dp[j-len]&&word.equals(s.substring(j-len,j)))就为true

3、dp数组初始化

初始化dp[0]=true,否则所有都为false

4、确定遍历顺序

本题要求是排列数,有顺序要求

5、打印dp数组

class Solution {public boolean wordBreak(String s, List wordDict) {boolean[] dp=new boolean[s.length()+1];//有空字符串dp[0]=true;for (int j=1;j<=s.length();j++){for (String word:wordDict){int len=word.length();if (j>=len&&dp[j-len]&&word.equals(s.substring(j-len,j))){dp[j]=true;break;}}}/*  for (int j=1;j<=s.length();j++){System.out.print(dp[j]+" ");}*/return dp[s.length()];}
}

相关内容

热门资讯

【两会热词追踪】寻梦香格里拉 ...   提到“云南礼物”,你会想到什么?  “我最先想到的是青稞。”谈起自己熟悉的产业,省人大代表、德钦...
半导体板块盈利能力显著改善 精... 1月30日晚间,精测电子发布2025年度业绩预告。公司预计2025年归属于上市公司股东的净利润为80...
激活国展商圈消费活力!香河园“... 转自:北京青年报客户端香河园“家乡年味大集”来啦!被誉为朝阳区北三环首席“菜篮子”的“柒号市集”商业...
多地GDP数据密集发布,“数字... 近日,全国多地陆续公布2025年经济数据“成绩单”:山东GDP首破10万亿元,江苏首破14万亿元,北...
英国首相斯塔默访沪:“机遇正在... (来源:中国台湾网)转自:中国台湾网  新华社上海1月31日电(记者唐斯琦)“‘盲人摸象’象征着世界...