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/

相关推荐
8Qi84 分钟前
LeetCode 337:打家劫舍 III(House Robber III)—— 题解 ✅
算法·leetcode·二叉树·动态规划
地平线开发者4 分钟前
从 INT64 Div 算子约束到 Cast 修复全流程
算法
2601_961194025 分钟前
教资科三美术考什么|初中高中美术题型考点和模板资料
leetcode·elasticsearch·职场和发展·蓝桥杯·pat考试·lucene
AI科技星7 分钟前
基于奇合数边界的离散解析数论与双螺旋宇宙本体大统一体系论文全部数学公式汇总表
人工智能·算法·机器学习·架构·学习方法
地平线开发者19 分钟前
Horizon 模型多 Batch 配置
算法·自动驾驶
我命由我1234527 分钟前
工程中安全帽颜色含义
运维·经验分享·学习·职场和发展·求职招聘·职场发展·学习方法
czhaii31 分钟前
GB2312简体中文编码表
单片机·算法
8Qi840 分钟前
LeetCode 121 & 122:股票买卖问题(DP 对比题解)✅
算法·leetcode·职场和发展·动态规划
一只齐刘海的猫1 小时前
【Leetcode】 接雨水
java·算法·leetcode
南境十里·墨染春水1 小时前
讲讲移动语义
算法