LeetCode讲解篇之139. 单词拆分

文章目录

题目描述

题解思路

我们使用一个数组记录字符串s在[0, i)区间能否使用wordDict组成

我们使用左右指针遍历字符串s的子串,左指针 j 为子串的左端点下标,右指针 i 为右端点下标的下一个

遍历过程中如果字符串s在[0, j)区间子串能被wordDict组成,则检查字符串s在[j, i)区间子串是否在wordDict中,如果在,则表明字符串s在[0, i)区间子串能被wordDict组成

题解代码

go 复制代码
func wordBreak(s string, wordDict []string) bool {
    n := len(s)
    wordMap := make(map[string]struct{}, len(wordDict))
    for _, word := range wordDict {
        wordMap[word] = struct{}{}
    }

    // s的[0, i)区间子串是否能用wordDict组成
    f := make([]bool, n + 1)

    f[0] = true

	// 遍历字符串的所有子串,注意右端点需要从左到右遍历,因为我们的计算需要用到右端点之前从零开始的子串是否能被wordDict组成,也就是我们依赖了f数组中[0,i)的数据
    for i := 1; i <= n; i++ {
        for j := 0; j < i; j++ {
            if f[j] {
            	// 如果左端点左边的子串可以被wordDict组成,则检查左端点到右端点能否被wordDict组成
                if _, ok := wordMap[s[j:i]]; ok {
                    f[i] = true
                    break
                }
            }
        }
    }

    return f[n]
}

题目链接

https://leetcode.cn/problems/word-break/description/

相关推荐
DFT计算杂谈15 分钟前
KPROJ编译教程
java·前端·python·算法·conda
重生之我是Java开发战士27 分钟前
【笔试强训】Week5:空调遥控, kotor和气球,走迷宫,主持人调度II,体操队形,二叉树的最大路径和,排序子序列,消减整数
java·算法·动态规划
吃好睡好便好2 小时前
用if…end…语句计算分段函数
开发语言·人工智能·学习·算法·matlab
灰灰勇闯IT2 小时前
ops-memory:CANN Runtime 的 Tensor 内存管理
算法
叶子Talk2 小时前
OpenAI破解80年数学猜想,AI首次做出原创证明
人工智能·数学·算法·机器学习·ai·openai·ai推理
MhZhou04122 小时前
1.11M参数小模型实现脑瘤分割 CVPR 2026 Findings 开源
算法·计算机视觉·3d·空间计算
有为少年2 小时前
Welford算法 | 从单一到批次
大数据·人工智能·深度学习·神经网络·算法·机器学习
吴可可1233 小时前
Teigha处理CAD样条曲线的方法解析
数据库·算法·c#
啊董dong3 小时前
noi-2026年5月12号小测验
数据结构·c++·算法
不知名的忻3 小时前
红黑树(简易版)
算法·红黑树