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/

相关推荐
W23035765735 分钟前
经典算法详解:最大子数组和(暴力 / 分治 / 动态规划 / 线段树)
算法·动态规划·最大字段和
呼啦啦5616 分钟前
leetcode练习——栈和队列
算法·leetcode·职场和发展
yugi98783818 分钟前
基于最大信息熵的粒子群优化算法图像分割(MATLAB实现)
开发语言·算法·matlab
计算机安禾28 分钟前
【数据结构与算法】第40篇:图论(四):最短路径——Dijkstra算法与Floyd算法
c语言·数据结构·算法·排序算法·哈希算法·图论·visual studio
SccTsAxR32 分钟前
算法进阶:贪心策略证明全攻略与二进制倍增思想深度解析
c++·经验分享·笔记·算法
2301_7926748637 分钟前
java学习day27(算法)
java·学习·算法
啦啦啦!1 小时前
c++AI大模型接入SDK项目
开发语言·数据结构·c++·人工智能·算法
lcj25111 小时前
【C语言】自定义类型1:结构体
c语言·开发语言·算法
jaysee-sjc1 小时前
十七、Java 高级技术入门全解:JUnit、反射、注解、动态代理
java·开发语言·算法·junit·intellij-idea
yongui478341 小时前
MATLAB模糊控制的粒子群算法(Fuzzy-PSO)实现
数据结构·算法·matlab