题目描述:
给定一个字符串s和一组单词dict,在s中添加空格将s变成一个句子,使得句子中的每一个单词都是dict中的单词
返回所有可能的结果
例如:给定的字符串s ="catsanddog",
dict =["cat", "cats", "and", "sand", "dog"].
返回的结果为["cats and dog", "cat sand dog"].

#include <iostream>
#include <vector>
#include <string>
#include <unordered_set>
using namespace std;
void Combine(vector<string>& v, const string& str) {
for (auto& e : v) { e += " " + str; }
}
vector<string> wordBreak(string s, unordered_set<string> &dict) {
vector<string> res;
if (dict.find(s) != dict.end())
res.push_back(s);
int len = s.size();
for (int i = 1; i < len; ++i)
{
string word = s.substr(i); //保存索引为第i到n-1个字符
/*find 用法:
从字符串的 pos 位置开始(若不指定 pos 的值,则默认从索引 0 处开始)
,查找子字符串 str。如果找到,则返回该子字符串首次出现时其首字符的索
引;否则,返回 string::npos:
find_first_of():在一个目标串中进行查找,返回值是第一个与指定字符组中任何字符匹配的字符位置。如果没有查找到匹配的内容,则返回npos。
find_last_of():在一个目标串中进行查找,返回最后一个与指定字符组中任何字符匹配的字符位置。如果没有查找到匹配的内容,则返回npos
find_first_not_of():在一个目标串中进行查找,返回第一个与指定字符组中任何字符都不匹配的元素位置。如果找不到那样的元素则返回npos
find_last_not_of():在一个目标串中进行查找,返回下标值最大的与指定字符组中任何字符都不匹配的元素的位置。若找不到那样的元素则返回npos。
rfind():对一个串从尾至头查找一个指定的单个字符或字符组。如果找到,就返回首次匹配的开始位置;如果没有查找到匹配的内容,则返回npos。
find(string, int):第一个参数用来指示要查找的字符,第二个参数用来表示从字符串的何处开始查找子串(默认的查找位置是0)。**
*/
if (dict.find(word) == dict.end())
continue; //若遍历到最后一个字符,word都不存在于dict
//word 在字典中找到
vector<string> tempRes = wordBreak(s.substr(0, i), dict);
Combine(tempRes, word);
res.insert(res.begin(), tempRes.begin(), tempRes.end());
}
return res;
}
void test()
{
string s = "catsanddog";
unordered_set<string> dict;
dict.insert("dog");
dict.insert("cat");
dict.insert("cats");
dict.insert("and");
dict.insert("sand");
vector<string> res = wordBreak(s, dict);
for (auto e : res)
{
cout << e << endl;
}
}
int main()
{
test();
exit(0);
}

本文介绍了一种基于给定单词字典的字符串拆分算法,通过递归方式在字符串中添加空格,使其变为由字典中单词组成的句子,并返回所有可能的结果。示例使用了catsanddog和包含catcatsandsanddog的字典。
351

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



