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

相关内容

热门资讯

给空压机换上“中国关节” 本报讯 (记者 苏益纯 通讯员 洪江武) 运行温度降低20℃,设备振动值明显下降,各项指标均优于改造...
敏于监督 速于办案   本报讯(全媒体记者匡雪 通讯员赵元桢)“判决结果出来了,我们追诉的上游供货商、监督立案的下线买家...
实地走访 护“桂”有方   近日,广东省肇庆市高要区检察院检察官来到当地肉桂企业,了解企业经营发展现状,结合办案进行风险提示...
伊拉克称不追究外国石油公司“不... 当地时间3月20日晚,伊拉克石油部消息人士称,伊拉克政府决定对在伊外国石油公司负责开发的所有油田实行...
伊朗总统:无意与伊斯兰国家发生... 来源:新华网新华社德黑兰3月20日电 据伊朗伊斯兰共和国通讯社报道,伊朗总统佩泽希齐扬20日表示,伊...