动态规划-子数组系列——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];
    }
};
相关推荐
凯瑟琳.奥古斯特12 小时前
力扣1235:加权区间调度最优解
java·python·算法·leetcode·职场和发展
耶叶13 小时前
餐厅出入最少人数问题:贪心算法
算法·贪心算法
gihigo199813 小时前
基于小波框架与稀疏表示的SAR图像目标识别系统(MATLAB实现)
算法
胡图图不糊涂^_^13 小时前
测试用例篇——设计测试用例的方法
笔记·学习·测试用例·判定表法·正交法生成用例测试·等价类·边界值
吴可可12313 小时前
CAD2004自定义实体开发环境配置
c++·算法
装不满的克莱因瓶13 小时前
矩阵的主成分是什么?主成分分析(PCA)又能做什么?
人工智能·线性代数·算法·机器学习·ai·矩阵·pca
大菜菜小个子13 小时前
template<typename T>使用
java·开发语言·算法
L_090713 小时前
【C++】C++11 新特性
开发语言·c++
Fanfanaas13 小时前
C++ 继承
java·开发语言·jvm·c++·学习·算法
lqqjuly13 小时前
模型合并与融合:理论、算法与可运行实现—从损失曲面几何到多模型融合
算法