当前位置:网站首页>leetcode经典例题——单词拆分
leetcode经典例题——单词拆分
2022-08-04 23:50:00 【你食不食油饼】
题目描述:
1、动态规划
思路:这道题是要我们单词拆分来,能用字符串列表这个数组组成,我们就可以用到动态规划:
初始化 dp=[false,……,false],长度为 n+1。n 为字符串长度。dp[i] 表示 s 的前 i 位是否可以用 wordDict 中的单词表示。初始化 dp[0]=True,空字符可以被表示。
当我们遍历s单词字符串时,如果dp[i] =false,则退出循环,证明我们无法拼接到这个位置;
如果dp[i] = true,我们遍历字符串列表,依次匹配,看是否能匹配至s单词字符串,匹配成功,则设置该位置dp[word.length+1] = true;
看看代码:
public boolean wordBreak(String s, List<String> wordDict) {
int len = s.length();
boolean[] dp = new boolean[len+1];
dp[0] = true;
for(int i = 0;i<len;i++){
if(!dp[i]) continue;
for(String word : wordDict){
while ( s.startsWith(word,i)){
dp[word.length()+i] = true;
break;
}
}
}
return dp[len];
}
时间复杂度:O(m*n),m为单词s的长度,n为字典wordDict的数量
空间复杂度:O(n)
2、回溯算法
思路:这道题既然是依次拼接,也就是一道排列组合题,我们也可以用回溯算法来解决
回溯算法就也是利用遍历wordDict,判断s.startsWith(word,i)为true时进行递归,
如果该次递归成功,我们返回结果true;
如果该次递归不成功,我们回溯,仍旧遍历wordDict进行判断是否下一次递归,直到wordDict遍历完成,仍没结果才返回false;
进入代码:
public boolean wordBreak(String s, List<String> wordDict) {
return backTrack(0,s,wordDict);
}
public boolean backTrack(int len,String s,List<String> wordDict){
if (len == s.length()) return true;
for (String word : wordDict) {
if (s.startsWith(word,len)){
if (backTrack(len+word.length(),s,wordDict))
return true;
}
}
return false;
}
注:该回溯算法有一个弊端,在leetcode运行时,由于它设置一个单词s为aaaaaaaaaaaaaa……wordDict["a","aa","aaa",……],我们用回溯算法时,由于会优先进行第一个"a"的匹配,所以可能出现超时情况!
持续更新关于leetcode的文章中~
边栏推荐
- 看图识字,DELL SC4020 / SCv2000 控制器更换过程
- 怎么将自己新文章自动推送给自己的粉丝(巨简单,学不会来打我)
- Privacy Computing Overview
- 话题 | 雾计算和边缘计算有什么区别?
- Nuclei(二)进阶——深入理解workflows、Matchers和Extractors
- uniapp横向选项卡(水平滚动导航栏)效果demo(整理)
- 【Valentine's Day special effects】--Canvas realizes full screen love
- 工业物联网 —— 新型数据库的召唤
- 中日颜色风格
- C5750X7R2E105K230KA(电容器)MSP430F5249IRGCR微控制器资料
猜你喜欢
MySQL基础篇【聚合函数】
OpenCV:10特征检测
Nuclei (2) Advanced - In-depth understanding of workflows, Matchers and Extractors
Bidding Announcement | Operation and Maintenance Project of Haina Baichuang Official Account
怎么将自己新文章自动推送给自己的粉丝(巨简单,学不会来打我)
大师教你3D实时角色制作流程,游戏建模流程分享
Security software Avast and Symantec NortonLifeLock merge with UK approval, market value soars 43%
Vscode连接远程服务器(一套配置成功)
Day118. Shangyitong: order list, details, payment
小黑leetcode之旅:95. 至少有 K 个重复字符的最长子串
随机推荐
游戏3D建模入门,有哪些建模软件可以选择?
LeetCode Hot 100
矩阵数学原理
LeetCode Hot 100
2022牛客暑期多校训练营5(BCDFGHK)
node中package解析、npm 命令行npm详解,node中的common模块化,npm、nrm两种方式查看源和切换镜像
SQL association table update
三、实战---爬取百度指定词条所对应的结果页面(一个简单的页面采集器)
golang 协程的实现原理
情人节---快来学习一下程序员的专属浪漫吧
10 个关于 Promise 和 setTimeout 知识的面试题,通过图解一次说透彻
【CVA估值训练营】财务建模指南——第一讲
小黑leetcode冲浪:94. 二叉树的中序遍历
Nuclei(二)进阶——深入理解workflows、Matchers和Extractors
情侣牵手[贪心 & 抽象]
npm基本操作及命令详解
【七夕快乐篇】Nacos是如何实现服务注册功能的?
Literature reading ten - Detect Rumors on Twitter by Promoting Information Campaigns with Generative Adversarial Learn
没有这些「伪需求」,产品经理的 KPI 怎么完成?
Modelers experience sharing: model study method