代码随想录算法训练营第四十六天| LeetCode139.单词拆分

news/2024/5/19 6:01:06

一、LeetCode139.单词拆分

题目链接/文章讲解/视频讲解:https://programmercarl.com/0139.%E5%8D%95%E8%AF%8D%E6%8B%86%E5%88%86.html

状态:已解决

1.思路 

        单词明显就是物品,字符串s明显就是背包,那么问题就变成了物品能不能把背包装满。

(1)确定dp数组以及下标的含义:

        dp[i]:字符串长度为i,dp[i]为true,代表长度为 i 的子串可以被单词组成。

(2)确定递推公式:

        对于dp[i],如果一个长为 wordDict[j].size() 的物品(单词)是s在[i-wordDict[j],i]这个范围内的子串,那么dp[i] = dp[j]的状态。

(3) 初始化dp数组:

        dp[0]表示如果字符串为空的话,说明出现在字典里。(实际题目中说了“给定一个非空字符串 s” 所以测试数据中不会出现i为0的情况,那么dp[0]初始为true完全就是为了推导公式。)

        下标非0的dp[i]初始化为false,只要没有被覆盖说明都是不可拆分为一个或多个在字典中出现的单词。

(4)确定遍历顺序:

        题目中说是拆分为一个或多个在字典中出现的单词,所以这是完全背包。本题其实我们求的是排列数, 拿 s = "applepenapple", wordDict = ["apple", "pen"] 举例。"apple", "pen" 是物品,那么我们要求 物品的组合一定是 "apple" + "pen" + "apple" 才能组成 "applepenapple"。"apple" + "apple" + "pen" 或者 "pen" + "apple" + "apple" 是不可以的,那么我们就是强调物品之间顺序。所以说,本题一定是 先遍历 背包,再遍历物品。且内外层都是从前往后遍历。

(5)举例推导dp:

以输入: s = "leetcode", wordDict = ["leet", "code"]为例,dp状态如图:

dp[s.size()]就是最终结果。

2.代码实现 

class Solution {
public:bool wordBreak(string s, vector<string>& wordDict) {vector<bool> dp(s.size()+1,false);dp[0] = true;for(int i=0;i<=s.size();i++){for(int j=0;j<wordDict.size();j++){if(wordDict[j].size() <= i){string word = s.substr(i-wordDict[j].size(),wordDict[j].size());if(!dp[i] && word == wordDict[j]){dp[i] = dp[i-wordDict[j].size()];}}}}//for(int i=0;i<=s.size();i++) cout<<dp[i]<<" ";return dp[s.size()];}
};

时间复杂度:O(n^3) :求子串是一个O(n)的复杂度

空间复杂度:O(n)


http://www.mrgr.cn/p/45087537

相关文章

梦境绘师:揭秘生成对抗网络(GAN)的魔法

梦境绘师&#xff1a;揭秘生成对抗网络&#xff08;GAN&#xff09;的魔法 1 引言 在今日的深度学习领域&#xff0c;生成对抗网络&#xff08;GAN&#xff09;已成为一项无人能外的技术&#xff0c;以其独特的数据生成能力俘获了无数研究者和工程师的心。这项技术不仅在理论上…

Qt静态编译后使用QtCipherSqlitePlugin静态编译库

Qt静态编译后使用QtCipherSqlitePlugin静态编译库 Qt静态编译后使用QtCipherSqlitePlugin静态编译库语文功底不好,标题起的有点绕口,解释一下:就是我使用的Qt是Qt5.15.2静态编译包(要Qt静态编译文件这里下载:QT5.15.2静态编译包下载 - koomee - 博客园 (cnblogs.com)…

jmeter:测试片段使用的踩坑点

1.坑点:测试片段保存后含有两层【测试片段】,这样引用测试片段是不会成功的,检查方法:打开测试片段看看是否只有一个层级测试片段 2.测试片段的正确使用步骤方法1:选中多个请求或者配置元件>鼠标右键,保存为测试片段(测试实施过程中最常用的方法)方法2:添加测试片…

自学编程两个月,现在我月入 4 万元

这个外国小哥叫 Nico,他一开始是个编程小白,后来把自己关在房间里花了两个月时间学会了编程,如今正在开发一款名为 Talknotes 的应用,可以将语音备忘录转化为结构化的内容,月收入 5000 美元。Nico 从高中毕业就开始创业,大学只上了一个月就退学了,他尝试了很多方向,最终…

echarts折线图使用dataZoom,切换数据时渲染异常,出现竖线bug

今天做项目遇到一个省份过多时,要加滚动条的需求。但是切换数据的时候,出现上图所出现的问题。经查资料,发现可以设置一个属性来解决这个问题。 filterMode: empty dataZoom: {show: this.xiaonengXData.length>12?true:false, // 为true 滚动条出现realtime: this…

ElasticSearch有账号密码时: kibana配置

上一篇文章我们介绍过ElasticSearch关闭账号密码的的方式&#xff1a; config/elasticsearch.yml文件中 xpack.security.enabled: false 当我们关闭 账号密码&#xff0c;kibana是可以直接访问ElasticSearch的。 真实项目中&#xff0c;我们是不允许数据库裸跑的&#xff0c;所…

01 背包的变形

01 背包的变形,退背包的思想消失之物 链接:https://www.luogu.com.cn/problem/P4141 题目描述 ftiasch 有 \(n\) 个物品, 体积分别是 \(w_1,w_2,\dots,w_n\)。由于她的疏忽,第 \(i\) 个物品丢失了。 “要使用剩下的 \(n-1\) 物品装满容积为 \(x\) 的背包,有几种方法呢?”—…

百兆集成网络链接器911105A

百兆集成网络链接器&#xff08;有时也称为百兆网卡&#xff09;是一种硬件设备&#xff0c;主要用于计算机与计算机网络之间的高速数据传输。它的主要功能包括&#xff1a; 1. 高速数据传输&#xff1a;百兆集成网络链接器支持100Mbps的数据传输速率&#xff0c;比之前的以太…

点击事件报错: Cannot set properties of null (setting onclick)

1、正常书写代码如下: 通过外部引用JS文件实现想要的效果时报错,以下是代码的展示。引入css文件 <script type="text/javascript" src="./win.js"></script>HTML代码文件如下:<div class="cl"><div id="mask"…

C++|模板进阶(非类型模板参数+特化)

目录 一、非类型模板参数 二、模板特化 2.1函数模板特化 2.2类模板特化 2.2.1全特化 2.2.2偏特化 三、模板不支持分离编译 四、模板优缺点 一、非类型模板参数 在模板初阶中&#xff0c;所学习的模板的参数是类型形参&#xff0c;但其实还有非类型形参。 类型形参&am…

Win10_x64 21h2调试体系分析

参考 https://www.52pojie.cn/thread-1728894-1-1.html记的笔记,发出来参考下,抛砖引玉,有错误多纠正。还望各位大佬别嘲笑。平台如下:版本 Windows 10 专业版版本号 21H2安装日期 2021-08-23操作系统内部版本 19044.2364体验 Windows Feat…

weditor替代品:uiauto.dev

weditor和uiauto.dev都是出自一个作者,是来自杭州某大厂现在weditor已经不更新了,作者重新写了一个uiauto.dev,界面比weditor更加友好现在还在测试阶段,但基本功能基本具备 demo地址:https://uiauto.devsleep.com/demo/12345 使用方法:https://uiauto.devsleep.com/

IDA技巧——结构体

参考 https://bbs.kanxue.com/thread-266419.htm 本文适用于初次使用IDA的小白(我本身也是小白),大佬请略过。 IDB快照 在我们开始修改结构体之前,首先为最初的IDB做一个快照是良好的习惯,这样可以帮助我们迅速还原某个时间点的IDB状态。比如我们改错了某个数据却没办法撤…

记录一下我hive连不上DataGrip的问题

用户名和密码都没问题&#xff0c;但报如下这个错误&#xff08;确保你的metastore和hiveserver2都是启动的&#xff0c;其次hdfs和yarn也是启动的&#xff09; 原因&#xff1a;是因为我在linux上没启hiveserver2服务 解决&#xff1a; [atguiguhadoop102 hadoop]$ …

PlayerSettings.WebGL.emscriptenArgs设置无效的问题

1)PlayerSettings.WebGL.emscriptenArgs设置无效的问题2)java.lang.NoSuchMethodError的不明崩溃问题3)UE电影摄像机旋转问题4)Android设备游戏切后台后唤起,有概率变卡且黑屏这是第383篇UWA技术知识分享的推送,精选了UWA社区的热门话题,涵盖了UWA问答、社区帖子等技术知…

海南陵水国际数字内容产业平台正式上线

4月14日&#xff0c;数创陵水链接全球——海南陵水国际数字内容产业平台上线发布会在陵水黎族自治县清水湾举行&#xff0c;来自全球各地的500余名商协会代表、企业家共同见证了平台上线&#xff0c;标志着陵水在推进数字化创新、打造国际数字内容产业新高地方面迈出坚实步伐。…

字节跳动(社招)三面算法原题

TikTok 喘息 继上月通过强制剥离 TikTok 法案后&#xff0c;美国众议院在当地时间 20 日下午以 360 票赞成 58 票反对通过了新的法案&#xff1a;剥离 TikTok 的期限由生效后 165 天调整至 270 天之内&#xff0c;即今年 11 月的美国总统大选后。 之前我们讲过&#xff0c;TikT…

python 实现网页 pdf 转 docx

1、安装 python 库 pip3 install flask PyPDF2 python-docx2、创建一个Flask应用,并编写处理文件上传和转换的代码 vim pdf_to_docx.py import os from flask import Flask, render_template, request, send_file from PyPDF2 import PdfReader from io import BytesIO from d…

超省电/低功耗LCD液晶断码驱动芯片VKL144C/D 适用于温控器,传感器,压力表 可驱动36SEGx4COM

VKL144C/D概述: VKL144C/D是一个点阵式存储映射的LCD驱动器,可支持最大144点(36SEGx4COM)的 LCD屏。单片机可通过I2C接口配置显示参数和读写显示数据,可配置4种功耗模式,也可通 过关显示和关振荡器进入省电模式。其高抗干扰,低功耗的特性适用于水电气表以及工控仪表 类产…