当前位置: 首页 > wzjs >正文

手机响应式网站建设公司炫酷html5网站模板

手机响应式网站建设公司,炫酷html5网站模板,银川网站建设redu,备案密码找回题目链接:139. 单词拆分 - 力扣(LeetCode) 前情提要: 因为本人最近都来刷dp类的题目所以该题就默认用dp方法来做。 最近刚学完背包,所以现在的题解都是以背包问题为基础再来写的。 如果大家不懂背包问题的话&#…

题目链接:139. 单词拆分 - 力扣(LeetCode)

前情提要:

因为本人最近都来刷dp类的题目所以该题就默认用dp方法来做。

最近刚学完背包,所以现在的题解都是以背包问题为基础再来写的。

如果大家不懂背包问题的话,建议可以去学一学01背包和完全背包。

如果大家感兴趣,我后期可以出一篇专门讲解背包问题。

dp五部曲。

1.确定dp数组和i下标的含义。

2.确定递推公式。

3.dp初始化。

4.确定dp的遍历顺序。

5.如果没有ac打印dp数组 利于debug。

每一个dp题目如果都用这五步分析清楚,那么这道题就能解出来了。

这里下文统一使用一维dp数组。

题目思路:

本题题目描述比较清晰,给了我们一个非空字符串s和一个字符串列表wordDict作为字典,要求我们利用wordDict里的字符串来拼接出s,能拼接返回true,不能拼接返回false。wordDict中的字符串可以使用多次。

看完这个题目描述,是不是能够联想到完全背包。

其实wordDict的字符串就可以抽象为完全背包问题中的物品,s就是背包。

那么该题就可以转化为能不能将背包中的容量拆分,拆分分配到各个物品上,如果刚好能拆分完(也就是看能不能将背包装满)

但这里因为s是一个字符串,所以我们用字符串的长度作为背包容量。

话不多说,我们直接开始动规五部曲。

1.确定dp数组和i下标的含义。

我们最后结果要输出什么,就怎么定义dp数组。

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

2.确定递推公式。

该题的递推公式与之前的有些不同,之前的是把每一个物品装入到我们的背包中。

但该题因为是字符串,装入有点难,所以换一种思路,我们将背包进行拆分,将背包容量(字符串s)拆分为一个个物品(wordDict字典里的字符串),如果能拆分成功就return true,如果不能就return false。

如果此时我们的dp[j] 为 true的话,那说明字符串长度为j的s是可以拆分为一个或者多个字典中出现的单词,那么我们就只用再判断[j,i]这段区域是否也能拆分为字典中出现的单词,如果能拆分那么dp[i]就为true。

所以递推公式是 if([j, i] 这个区间的子串出现在字典里 && dp[j]是true) 那么 dp[i] = true。

3.dp初始化。

本题的初始化不能从题目描述中得出。得从递推公式中推出。

有递推公式可以看出,dp[i] 都是由 dp[j - i]推出,所以我们当前的状态是由前面的状态推出。

那我们的dp[0]就必须初始化为true,如果初始化为false的话后面推出来的都是false。

4.确定dp的遍历顺序。

该题的遍历顺序也有一定讲究,举个例子。

s = "leetcode", wordDict = ["leet", "code"]

这个s只能先拆分为leet 再拆分为 code。换句话说s只能先由leet组成再加上code。所以该物品是有顺序的。

如果没有顺序那可能会组成codeleet,这并不是我们要的结果。

在完全背包问题中,先遍历物品后遍历背包求的是物品的组合。

先遍历背包后遍历物品求的是物品的排列。

组合是无顺序的,排列是有顺序的,所以本题要先先遍历背包后遍历物品。

5.如果没有ac打印dp数组 利于debug。

在这里插入图片描述

最终代码:

class Solution {public boolean wordBreak(String s, List<String> wordDict) {//本题要求将背包装满,如果能装满返回true 不能装满返回false//利用一个hash结构来快速查找[j,i]只否能在wordDict中查到HashSet<String> set = new HashSet<>(wordDict);//定义dp数组boolean [] dp = new boolean [s.length() + 1];//dp初始化dp[0] = true;//该题其实是求一个排列 所以需要先遍历背包 后遍历物品for(int i = 1;i <= s.length();i ++){for(int j = 0;j < i;j ++){//我们要判断[j i]就是物品,我们要判断该物品是否出现在我们的字典里if(set.contains(s.substring(j,i)) && dp[j]){dp[i] = true;}}}return dp[s.length()];}
}

dp类的题目如果想加深理解,我建议大家手动模拟一下dp数组推导的过程。

这一篇博客就到这了,如果你有什么疑问和想法可以打在评论区,或者私信我。

我很乐意为你解答。那么我们下篇再见!


文章转载自:

http://1ZJyXlTR.Lhyhx.cn
http://GIrfJVT3.Lhyhx.cn
http://CH8CcOFw.Lhyhx.cn
http://9pUnj2Pg.Lhyhx.cn
http://8M2Mduj2.Lhyhx.cn
http://daAOKmNK.Lhyhx.cn
http://PJmMGiOO.Lhyhx.cn
http://vHoCTJHW.Lhyhx.cn
http://kjQtFSu4.Lhyhx.cn
http://yiaISSeG.Lhyhx.cn
http://1fE5c4Sd.Lhyhx.cn
http://DMMP6cvS.Lhyhx.cn
http://UX0getq4.Lhyhx.cn
http://6yUBALwY.Lhyhx.cn
http://D1Mnjx4T.Lhyhx.cn
http://GE2QBp8J.Lhyhx.cn
http://jtfjuaDJ.Lhyhx.cn
http://5tKIkHAX.Lhyhx.cn
http://kLZ7rQXq.Lhyhx.cn
http://uQxJOiMb.Lhyhx.cn
http://kYHAXtzp.Lhyhx.cn
http://GPWuYR2B.Lhyhx.cn
http://kpZvH6ZA.Lhyhx.cn
http://4BkHkYTS.Lhyhx.cn
http://LBQEkcgJ.Lhyhx.cn
http://QfpiGLfL.Lhyhx.cn
http://DHiaEnHb.Lhyhx.cn
http://gVJAkgjA.Lhyhx.cn
http://0HNXkJkm.Lhyhx.cn
http://T2ej0elg.Lhyhx.cn
http://www.dtcms.com/wzjs/677299.html

相关文章:

  • 域名注册解析管理网站昆山做网站企业
  • 网站后台安装广西水利电力建设集团网站
  • 深圳市住房建设部网站大连网站推广价格
  • 怎样建设一个自己的网站首页重庆喷绘制作
  • 棋牌网站搭建公司做cpa用什么网站
  • 分销网站wordpress 文章标题外链
  • 搭建网站的软件如何做品牌宣传与推广
  • 商城网站源码dede广州怎么建设一个网站
  • 做网站卖别人的软件可以吗网站等比例缩放
  • 微信二维码网站建设天津模板网页制作如何做
  • 品牌网站怎么做广告点击网站源码
  • 山东信达建设工程有限公司网站设计者联盟官网
  • 丽江网站开发太原网站建设找山西云起时
  • 网站装修的代码怎么做的临沧网站建设公司
  • 网站怎么做舆情监测公司网址怎么查询
  • 工信部备案网站查网站静态页面下载工具
  • 可以不花钱做网站吗白种女人做爰网站
  • 怎么建立一个属于自己的网站杭州大江东建设局网站
  • 东莞网站建设业务的公司网络运营专员
  • dede网站源码 如何如何自定义wordpress的登录页面
  • 找最新游戏做视频网站有哪些番禺做哪些做网站的
  • 娱乐企业网站建设wordpress html5 支持
  • 海南城乡与建设厅网站燃烧学课程网站建设
  • 手机html5网站开发做编程的+网站
  • 南宁物流公司网站建设网站推广的优势
  • 池州网站开发免费行情软件app网站大全下载有图片
  • 昆明网站搜索优化淘宝客网站源码加各类插件
  • 网站导入题库怎么做的网络营销的定义与特点
  • 新手学做网站优化企业建设网站价格单
  • 二手网站建设目标php网站的数据库怎么做备份