- 单词拆分
给你一个字符串 s 和一个字符串列表 wordDict 作为字典。请你判断是否可以利用字典中出现的单词拼接出 s 。
注意:不要求字典中出现的单词全部都使用,并且字典中的单词可以重复使用。
示例 1:
输入: s = “leetcode”, wordDict = [“leet”, “code”]
输出: true
解释: 返回 true 因为 “leetcode” 可以由 “leet” 和 “code” 拼接成。
示例 2:
输入: s = “applepenapple”, wordDict = [“apple”, “pen”]
输出: true
解释: 返回 true 因为 “applepenapple” 可以由 “apple” “pen” “apple” 拼接成。
注意,你可以重复使用字典中的单词。
示例 3:
输入: s = “catsandog”, wordDict = [“cats”, “dog”, “sand”, “and”, “cat”]
输出: false
提示:
1 <= s.length <= 300
1 <= wordDict.length <= 1000
1 <= wordDict[i].length <= 20
s 和 wordDict[i] 仅有小写英文字母组成
wordDict 中的所有字符串 互不相同
通过次数251,647提交次数479,720
回溯,超出时间限制
class Solution {
private:
bool is_inDict(string str,unordered_set<string> my_set)
{
if(my_set.find(str)!=my_set.end())
{
return true;
}
return false;
}
string result;
bool flag=false;
string path;
void BackTracking(string s, unordered_set<string> my_set, int strat_index)
{
if(flag==true)
return;
if(path==s)
{
flag=true;
return;
}
for(int i=strat_index;i<s.size();i++)
{
string temp=s.substr(strat_index,i-strat_index+1);
if(is_inDict(temp,my_set))
{
path+=temp;
BackTracking(s,my_set,i+1);
path.erase(path.size()-temp.size(),temp.size());
}
}
}
public:
bool wordBreak(string s, vector<string>& wordDict) {
unordered_set<string> my_set;
for(int i=0;i<wordDict.size();i++)
{
my_set.insert(wordDict[i]);
}
BackTracking(s,my_set,0);
return flag;
}
};
动态规划 完全通过
class Solution {
public:
bool wordBreak(string s, vector<string>& wordDict) {
unordered_set<string> my_set(wordDict.begin(),wordDict.end());
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++)
{
string word=s.substr(j,i-j);
if(my_set.find(word)!=my_set.end()&&dp[j]==true)
{
dp[i]=true;
}
}
}
return dp[s.size()];
}
};