当前位置: 首页 > article >正文

LeetCode讲解篇之139. 单词拆分

文章目录

  • 题目描述
  • 题解思路
  • 题解代码
  • 题目链接

题目描述

在这里插入图片描述

题解思路

我们使用一个数组记录字符串s在[0, i)区间能否使用wordDict组成
我们使用左右指针遍历字符串s的子串,左指针 j 为子串的左端点下标,右指针 i 为右端点下标的下一个
遍历过程中如果字符串s在[0, j)区间子串能被wordDict组成,则检查字符串s在[j, i)区间子串是否在wordDict中,如果在,则表明字符串s在[0, i)区间子串能被wordDict组成

题解代码

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/


http://www.kler.cn/news/336239.html

相关文章:

  • JS模块化工具requirejs详解
  • webpack/vite的区别
  • Oracle架构之物理存储之日志文件
  • 计算机毕业设计 基于Python的智能文献管理系统的设计与实现 Python+Django+Vue 前后端分离 附源码 讲解 文档
  • 【图像处理】多幅不同焦距的同一个物体的平面图象,合成一幅具有立体效果的单幅图像原理(一)
  • MFC工控项目实例二十二主界面计数背景颜色改变
  • 股市突然暴涨,需要保持理性
  • 突触可塑性与STDP:神经网络中的自我调整机制
  • 探索MinimalModbus:Python中强大的Modbus通信库
  • 【WSL】wsl中ubuntu无法通过useradd添加用户
  • 论文速读:基于渐进式转移的无监督域自适应舰船检测
  • CMU 10423 Generative AI:lec14(Vision Language Model:CLIP、VQ-VAE)
  • WPF 设计属性 设计页面时实时显示 页面涉及集合时不显示处理 设计页面时显示集合样式 显示ItemSource TabControl等集合样式
  • Java如何判断堆区中的对象可以被回收了?
  • 【含开题报告+文档+PPT+源码】基于SSM + Vue的养老院管理系统【包运行成功】
  • 树莓派 mysql (兼容mariadb)登陆问题
  • 【c++】知识精讲:c++数组排序的方法归纳
  • 设置服务器走本地代理
  • 操作系统 | 学习笔记 | 王道 | 4.1 文件系统基础
  • 论文阅读:Attention is All you Need