算法与数据结构(单词拆分)

题目

思路

动态规划

这道题可以利用动态规划来判断字符串 s 是否能被拆分成字典 wordDict 中的单词。具体做法是:先将字典存入哈希集合以便快速查找,然后初始化一个 dp 数组,其中 dpi 表示 s 的前 i 个字符能否被拆分。初始时 dp0 设为 true(空字符串可拆分),接着遍历字符串,对于每个位置 i,检查所有可能的分割点 j,如果前 j 个字符可拆分(dpj 为 true)且子串 sj..i-1 在字典中,则标记 dpi 为 true。最终,dps.size() 的值即为整个字符串 s 是否能被拆分的结果。

代码详解

首先我们可以将wordDict中的单词全都存入哈希表中,方便后面的判断。

接着定义dp,它是用来判断前面的字符能否被拆分。若dpi为false,则表示不可以。相反,若为true则为可以。

至于为什么创建它时空间为s.size()+1

因为 dpi 表示的是 前 i 个字符,而 s 的索引是从 0 开始的:

s0..i-1 对应 dpi(前 i 个字符)。

如果 dp 的大小是 s.size(),那么 dps.size() 就无法表示整个字符串(因为 s.size() 是 8,但 dp8 需要表示 s0..7)。

dp0=true意味着空字符串可以被拆分

i变量是用来遍历所有可能的前缀长度,j是用来遍历所有的分割点。

s0,j-1能否被拆分(由dpj)决定

sj,i是否在字典中(由 wordDictSet.find() 决定)

代码

cpp 复制代码
class Solution {
public:
    bool wordBreak(string s, vector<string>& wordDict) 
    {
           auto wordDictSet = unordered_set<string> ();
           for(auto &x: wordDict)
           {
                wordDictSet.insert(x);
           }
           vector<bool> dp(s.size()+1); // 默认是false
           dp[0]=true;
           for(int i=1;i<=s.size();i++)
           {
                for(int j=0;j<i;j++)
                {
                    if(wordDictSet.find(s.substr(j,i-j))!=wordDictSet.end() && dp[j])
                    {
                        dp[i] = true;
                        break;
                    }
                }
           }
           return dp[s.size()];
    }
};
相关推荐
2501_906565129 小时前
勾股定理证明
算法
Shan12059 小时前
无向图的Hierholzer算法流程(二)
算法
gihigo199810 小时前
基于蒙特卡洛的异常值剔除(RANSAC + MC置信区间)—MATLAB实现
开发语言·算法·matlab
Asize10 小时前
数组数据结构底层:从灵活到陷阱
前端·javascript·算法
hairenwangmiao10 小时前
B4041 [GESP202409 四级] 区间排序
算法·排序
人道领域11 小时前
【LeetCode刷题日记】47.全排列Ⅱ
java·开发语言·算法·leetcode
漂流瓶jz11 小时前
UVA-1606 两亲性分子 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·向量·aoapc·算法竞赛入门经典·atan2·浮点
Navigator_Z11 小时前
LeetCode //C - 1095. Find in Mountain Array
c语言·算法·leetcode
不会就选b11 小时前
算法日常・每日刷题--<二分查找>1
算法
Chen_harmony11 小时前
二、顺序表
数据结构