面试算法-99-单词拆分

题目

给你一个字符串 s 和一个字符串列表 wordDict 作为字典。如果可以利用字典中出现的一个或多个单词拼接出 s 则返回 true。

注意:不要求字典中出现的单词全部都使用,并且字典中的单词可以重复使用。

示例 1:

输入: s = "leetcode", wordDict = ["leet", "code"]

输出: true

解释: 返回 true 因为 "leetcode" 可以由 "leet" 和 "code" 拼接成。

java 复制代码
class Solution {
    public boolean wordBreak(String s, List<String> wordDict) {
        int n = s.length();
        boolean[] dp = new boolean[n + 1];
        dp[0] = true;
        for (int i = 0; i <= n; i++) {
            if (!dp[i]) {
                continue;
            }
            for (String word : wordDict) {
                if (i + word.length() <= n && s.startsWith(word, i)) {
                    dp[i + word.length()] = true;
                }
            }
        }
        return dp[n];
    }
}
相关推荐
Lee川16 小时前
深度解构JavaScript:作用域链与闭包的内存全景图
javascript·面试
CoovallyAIHub17 小时前
语音AI Agent编排框架!Pipecat斩获10K+ Star,60+集成开箱即用,亚秒级对话延迟接近真人反应速度!
深度学习·算法·计算机视觉
UrbanJazzerati18 小时前
Python Scrapling反爬虫小技巧之Referer
后端·面试
一点一一18 小时前
从输入URL到页面加载:浏览器多进程/线程协同的完整逻辑
前端·面试
木心月转码ing20 小时前
Hot100-Day14-T33搜索旋转排序数组
算法
暮色妖娆丶21 小时前
不过是吃了几年互联网红利罢了,我高估了自己
java·后端·面试
UrbanJazzerati21 小时前
Python Scrapling:小白也能轻松掌握的现代网页抓取工具
后端·面试
Lee川21 小时前
🚀《JavaScript 灵魂深处:从 V8 引擎的“双轨并行”看执行上下文的演进之路》
javascript·面试
zone77391 天前
004:RAG 入门-LangChain读取PDF
后端·python·面试
会员源码网1 天前
内存泄漏(如未关闭流、缓存无限增长)
算法