力扣-单词拆分

class Solution {

public boolean wordBreak(String s, List<String> wordDict) {

//目标:判断字符串s是否可以用wordDict中的单词组成(wordDict中的单词可以重复使用,也可以不全部用完)

//暴力法:

// s = 'leetcode'

//先试字典中的"leet" 检查leetcode是否以"leet"开头 去掉它 剩下子串是code 再递归去判断code能不能被拆分

return canBreak(s,wordDict);

}

//这个字符串s是否可以被成功拆分

public boolean canBreak(String s,List<String> wordDict){

if(s.isEmpty()){//空的也算

return true;

}

for(String word:wordDict){

if(s.startsWith(word)){

//如果是的 那么继续递归处理剩余字符串

if(canBreak(s.substring(word.length()),wordDict)){

return true;

}

}

}

return false;

}

}

相关推荐
被开发耽误的大厨14 小时前
1、==、equals、hashCode底层原理?重写场景?
算法·哈希算法
WolfGang00732115 小时前
代码随想录算法训练营 Day38 | 动态规划 part11
算法·动态规划
松☆16 小时前
C++ 算法竞赛题解:P13569 [CCPC 2024 重庆站] osu!mania —— 浮点数精度陷阱与 `eps` 的深度解析
开发语言·c++·算法
jr-create(•̀⌄•́)16 小时前
正则化和优化算法区别
pytorch·深度学习·神经网络·算法
li星野17 小时前
刷题:数组
数据结构·算法
tankeven18 小时前
HJ182 画展布置
c++·算法
CS_Zero20 小时前
无人机路径规划算法——EGO-planner建模总结—— EGO-planner 论文笔记(一)
论文阅读·算法·无人机
杰梵20 小时前
聚酯切片DSC热分析应用报告
人工智能·算法
@BangBang20 小时前
leetcode (4): 连通域/岛屿问题
算法·leetcode·深度优先