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()];}
}

相关内容

热门资讯

10年期美债收益率跌约4个基点... 格隆汇12月19日|周四(12月18日)纽约尾盘,美国10年期国债收益率跌3.90个基点,报4.11...
CBOT玉米期货涨0.79%,... 每经AI快讯,周四(12月18日)纽约尾盘,彭博谷物分类指数涨0.29%,报29.1385点。CBO...
医学会、医院、药企携手共筑家门...   本报讯 记者张晓莉报道 12月18日,一场聚焦中老年健康,以“健康暖冬·关爱随行”为主题的科普进...
杏林逐梦 医心若磐 转自:贵州日报松桃自治县民族中医院骨伤二科内景。 (松桃自治县民族中医院供图) 陈君扬 郭进 侯桂...
创新援外硕士项目品牌 助力构建... 援外人力资源开发合作是中国践行以人民为中心的发展理念、推动构建人类命运共同体的重要实践,也是中国对外...