DP:segment string

Segment a long string into a set of valid words using a dictionary. Return the maximum number  of the subwords.

此题出自facebook面试题。

方法一:套用矩阵连乘积模型。复杂度O(N^3)

int segmentString(string str, set<string> dict)
{ // O(N^3)
    int len = str.length();
    vector<vector<int> > f(len, vector<int>(len, 0));
    for (int k = 0; k < len; ++k)
    {
        for (int i = 0; i < (len - k); ++i)
        {
            int j = i + k;
            if (dict.find(str.substr(i, k + 1)) != dict.end())
            {
                f[i][j] = 1;
            }
            for (int t = i; t < j; ++t)
            {
                if (f[i][t] && f[t+1][j])
                {
                    f[i][j] = max(f[i][j], f[i][t] + f[t+1][j]);
                }
            }
        }
    }

    return f[0][len-1];
}

套用最长上升子序列:复杂度O(N^2)

int segmentString2(string str, set<string> dict)
{
    int len = str.length();
    vector<int> f(len, 0);
    for (int i = 0; i < len; ++i)
    {
        for (int j = i-1; j >= 0; --j)
        {
            if (dict.find(str.substr(j + 1, i)) != dict.end() &&
                f[j])
            {
                f[i] = max(f[i], f[j] + 1);
            }
        }
    }
    return f[len - 1];
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 你可以使用 C++ 的 string 类的 find 和 substr 函数来分割 std::string 字符串。 例如,如果你想要将字符串按照逗号分割,你可以使用以下代码: ``` #include <iostream> #include <string> #include <vector> std::vector<std::string> split(const std::string& str, char delimiter) { std::vector<std::string> tokens; std::string token; std::istringstream tokenStream(str); while (std::getline(tokenStream, token, delimiter)) { tokens.push_back(token); } return tokens; } int main() { std::string str = "apple,banana,orange"; char delimiter = ','; std::vector<std::string> tokens = split(str, delimiter); for (const std::string& token : tokens) { std::cout << token << std::endl; } return 0; } ``` 输出结果为: apple banana orange ### 回答2: std::string 字符串分割的 c++ 代码可以使用以下方式实现: ```cpp #include <iostream> #include <string> #include <vector> #include <sstream> std::vector<std::string> splitString(const std::string& str, char delimiter) { std::vector<std::string> result; std::stringstream ss(str); std::string token; while (std::getline(ss, token, delimiter)) { result.push_back(token); } return result; } int main() { std::string str = "Hello,World,This,is,a,test"; std::vector<std::string> words = splitString(str, ','); for (const std::string& word : words) { std::cout << word << std::endl; } return 0; } ``` 以上代码中的 splitString 函数接受两个参数,一个是要分割的字符串 str,另一个是分隔符 delimiter。通过使用 std::stringstream 类来进行字符串的分割操作。首先将要分割的字符串 str 传入到 stringstream 对象 ss 中,然后使用 getline 函数从 ss 中按照指定的分隔符 delimiter 提取每个子字符串,并将其存储到 result 向量中。最后返回存储了分割结果的向量。 在 main 函数中,我们可以看到示例代码将一个包含逗号的字符串进行了分割。逗号是作为分隔符进行字符串的分割。分割结果存储在向量 words 中,并通过循环将每个子字符串输出到控制台上。 ### 回答3: 要实现字符串分割的c代码,可以使用标准库中的std::string类及其成员函数和标准库中的stringstringstream来实现。以下是一个示例代码: ```c++ #include <iostream> #include <sstream> #include <string> #include <vector> std::vector<std::string> splitString(const std::string& input, char delimiter) { std::istringstream iss(input); std::vector<std::string> result; std::string segment; while (std::getline(iss, segment, delimiter)) { result.push_back(segment); } return result; } int main() { std::string input = "Hello,World,This,is,a,string"; char delimiter = ','; std::vector<std::string> substrings = splitString(input, delimiter); for (const std::string& substring : substrings) { std::cout << substring << std::endl; } return 0; } ``` 以上代码中,splitString函数接受两个参数,一个是输入字符串input,另一个是分割符delimiter。函数内部使用std::istringstream将input包装成流以便逐段读取。然后通过std::getline函数的第三个参数delimiter指定每段的分割符,并将每个分段segment存入vector容器result中。最后,函数返回分割的结果。 在主函数中,定义了一个输入字符串input和一个分割符delimiter,并通过调用splitString函数将input按delimiter进行分割。然后,通过遍历substrings容器输出分割后的子串。 以上是一个基本的字符串分割c代码示例,通过使用std::string类和stringstringstream,可以方便地实现字符串的分割功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值