(1)动态规划
class Solution {
public:
bool wordBreak(string s, vector<string>& wordDict) {
int len=wordDict.size();
unordered_set<string> st;
for(int i=0;i<len;i++) {
st.insert(wordDict[i]);
}
vector<bool> v(s.size()+1,false);
v[0]=true;
for(int i=1;i<s.size()+1;i++) {
for(int j=0;j<i;j++) {
if(v[j]&&(st.find(s.substr(j,i-j))!=st.end())) {
v[i]=true;
break;
}
}
}
return v[s.size()];
}
};

本文解析了如何使用动态规划算法解决字符串wordBreak问题,通过wordDict找出s中能由字典中的单词组成的部分。代码实现展示了如何利用unordered_set存储并遍历子串,利用布尔数组记录是否能构成完整单词。
684

被折叠的 条评论
为什么被折叠?



