当前位置:网站首页>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的文章中~
边栏推荐
- MYS-6ULX-IOT 开发板测评——使用 Yocto 添加软件包
- Security software Avast and Symantec NortonLifeLock merge with UK approval, market value soars 43%
- 上课笔记(6)(2)——#742. 周末舞会
- 【手撕AHB-APB Bridge】~ AMBA总线 之 AHB
- Xiaohei's leetcode journey: 95. Longest substring with at least K repeating characters
- [LeetCode] Summary of Matrix Simulation Related Topics
- uniapp sharing function - share to friends group chat circle of friends effect (sorting)
- 基于Appian低代码平台开发一个SpaceX网站
- uniapp horizontal tab (horizontal scrolling navigation bar) effect demo (organization)
- uniapp 分享功能-分享给朋友群聊朋友圈效果(整理)
猜你喜欢
随机推荐
4 - "PyTorch Deep Learning Practice" - Backpropagation
情人节---快来学习一下程序员的专属浪漫吧
NebulaGraph v3.2.0 Release Note, many optimizations such as the performance of querying the shortest path
C5750X7R2E105K230KA(电容器)MSP430F5249IRGCR微控制器资料
Xiaohei leetcode surfing: 94. Inorder traversal of binary tree
请你说一下final关键字以及static关键字
线程三连鞭之“线程的状态”
golang 协程的实现原理
DNS常见资源记录类型详解
What is next-generation modeling (with learning materials)
Flutter启动流程(Skia引擎)介绍与使用
Literature reading ten - Detect Rumors on Twitter by Promoting Information Campaigns with Generative Adversarial Learn
话题 | 雾计算和边缘计算有什么区别?
Some thoughts on writing
[LeetCode] Summary of Matrix Simulation Related Topics
VMware NSX 4.0 -- 网络安全虚拟化平台
PZK学C语言之字符串函数(一)
SQL association table update
@Async注解的作用以及如何实现异步监听机制
npm基本操作及命令详解