动态规划-子数组系列——139.单词拆分

1.题目解析

题目来源:139.单词拆分------力扣

测试用例

2.算法原理

1.状态表示

创建dp表,dpi表示:以第i个位置为结尾前面的字符串是否可以使用字典中的单词拼凑而成

所以dp表存储的是bool类型的数据

2.状态转移方程

这里的状态转移方程不是很重要,重要的是如何判断一个字符串是否可以使用字典中的单词拼凑而成,这里的思路就是首先使用i向后移动遍历字符串每个长度的子数组,使用j指针从i位置向前移动,判断区间1,j-1以及j,i这两个区间是否都可以被字典中的单词拼凑出来,是则将dpi置为true

3.初始化

开辟一个虚拟节点置为true,不会影响填表顺序也可以直接在循环内初始化

4.填表顺序

从左到右

5.返回值

返回最后一个位置的dp表的值

3.实战代码

cpp 复制代码
class Solution {
public:
    bool wordBreak(string s, vector<string>& wordDict) 
    {
        int n = s.size();
        unordered_set<string> hash;
        for(auto& e : wordDict)
        {
            hash.insert(e);
        }
        s = ' ' + s;

        vector<bool> dp(n+1);
        dp[0] = true;

        for(int i = 1;i <= n;i++)
        {
            for(int j = i;j >= 1;j--)
            {
                if(dp[j-1] && hash.count(s.substr(j,i-j+1)))
                {
                    dp[i] = true;
                }
            }
        }
        return dp[n];
    }
};
相关推荐
有点。3 分钟前
C++(二分答案)
c++
程序喵大人5 分钟前
【C++并发系列】第一章:多线程读写同一个变量为什么会出错
开发语言·c++·多线程·并发
踏着七彩祥云的小丑12 分钟前
嵌入式测试学习第33 天:压力测试、反复开关机、反复插拔接口测试
单片机·嵌入式硬件·学习
zhengzhouliuhaha22 分钟前
智能医疗设备控费系统:以全院一体化管控,筑牢医疗资源“安全阀”
大数据·数据结构·人工智能·算法·安全·机器学习·软件需求
June`24 分钟前
CUDA程序效率如何计算以及工具如何使用
算法·cuda
兰令水27 分钟前
leecodecode【树形DP】【2026.6.11打卡-java版本】
java·算法·深度优先
装不满的克莱因瓶34 分钟前
RLHF中的PPO算法——大语言模型对齐优化的核心引擎
人工智能·python·深度学习·算法·机器学习·语言模型·自然语言处理
梓䈑34 分钟前
C++ 接入 SQLite 数据库:环境搭建、API 详解 与 两种执行方式对比
数据库·c++·sqlite
fox_lht1 小时前
14.6.将错误重定向到标准错误
开发语言·后端·学习·rust
fanged1 小时前
Linux内核学习17--SPI子系统(TODO)
学习