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

相关内容

热门资讯

中光学聘任61岁刘洋为非独立董... 6月18日,中光学公告,聘任刘洋先生为公司非独立董事。资料显示,刘洋,男,1965年出生,中国国籍,...
丽尚国潮股东杭州骥瑜商业管理有... 6月18日消息,丽尚国潮股东杭州骥瑜商业管理有限公司于2026年6月16日,通过大宗交易方式减持15...
国盛证券总经理赵景亮新任董事,... 6月18日,国盛证券公告,聘任赵景亮先生为公司董事。资料显示,赵景亮先生,1978年12月出生,特许...
成人超重率超三成 我国肥胖形势... (来源:千龙网)新华社北京6月17日电 当前我国成人超重率约为34.3%,肥胖率约为16.4%;6岁...
卢浮宫馆长称该博物馆已“不堪重... (来源:千龙网)新华社巴黎6月17日电 法国卢浮宫博物馆馆长克里斯托夫·勒里博17日就博物馆内设施设...