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

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] = truebreak}}}}return f[n]
}

题目链接

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


http://www.mrgr.cn/news/44250.html

相关文章:

  • 设计模式之装饰器模式(Decorator)
  • history的pushState/replaceState理解
  • vSAN05:vSAN延伸集群简介与创建、资源要求与计算、高级功能配置、维护、故障处理
  • 突触可塑性与STDP:神经网络中的自我调整机制
  • 电子信息类专业技术学习及比赛路线总结(大一到大三)
  • LeetCode hot100---栈专题(C++语言)
  • 10月5日刷题记录
  • 数据结构与算法篇(树 - 常见术语)
  • vue.js组建开发
  • 数据结构与算法篇(图)(持续更新迭代)
  • 【LeetCode-热题100-128题】官方题解好像有误
  • 【重学 MySQL】五十八、文本字符串(包括 enum set)类型
  • 如 有 任 何 问 题 ,请 及 时 联 系 我 们 反 馈 !
  • 一个值得关注的3D生成新算法:速度和图像生成平齐,能生成合理的展开贴图和高质量mesh
  • 19年408数据结构
  • 【Blender Python】3.使用For循环和列表批量创建立方体
  • 重磅来袭!CMSIS-DAP 脱机烧录器 EasyFlasher 发布~
  • STL-优先级队列使用总结
  • 10.6字符驱动设备
  • 力扣之1322.广告效果