美文网首页
两个字符串的第二长公共单词

两个字符串的第二长公共单词

作者: FlyingPig_ | 来源:发表于2019-01-30 21:24 被阅读4次

问题

功能是求出字符 s 与字符串t的第二公共单词(这里,假设两个
字符串均由英字母和空格字符组成);若找到这样的公共单词,
函数返回该单词,否则,函数返回NULL,如果有多个满足要
求,则返回第一个单词。

例如:若 s=“This is C programming text”,t=“This is a text for C
programming”,则函数返回“this”。

思路

先将字符串分解成为数组, 再对数组内容进行比较, 将比较获得的结果储存起来, 最后按照长度排序获得答案.

解决方案

C++

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>

using namespace std;

string solution(string& s, string& t); 
vector<string> split(string& s);  //将字符串分解为字符串数组
bool compareLen(const string& a, const string& b) 
{  
    return (a.size() > b.size());
}

int main()
{
    string s("This is C programming text");
    string t("This is a text for C programming");
    string r = solution(s, t);

    cout << r << "\n";
    return 0;
}

string solution(string& s, string& t)
{
    //分词, 讲两个字符串按照空格分解
    vector<string> ss = split(s);
    vector<string> tt = split(t);
    //对比获得的两个数组,逐个比较
    vector<string> result;
    for(auto &&sstr : ss){
        for(auto &&tstr : tt){
            if(sstr == tstr){
                result.push_back(sstr);
            }
        }
    }
    //sort and get the result
    sort(result.begin(), result.end(), compareLen);
    if(result.size() > 1)
        return result.at(1);
    else if(result.size() == 1)
        return result.front();
    else
        return "NULL";
}

vector<string> split(string& s)
{
    vector<string> out;
    vector<size_t> blankPos;
    for(size_t i = 0; i < s.size(); ++i){
        if(s.at(i) == ' '){
            blankPos.push_back(i);
        }
    }
    if(blankPos.front() != 0){
        blankPos.insert(blankPos.begin(), 0);
    }
    if(blankPos.back() != s.size()){
        blankPos.push_back(s.size());
    }

    for(size_t i = 1; i < blankPos.size(); ++i){
        out.push_back(s.substr(blankPos.at(i - 1), blankPos.at(i) - blankPos.at(i - 1)));
    }
    return out;
}

相关文章

  • 两个字符串的第二长公共单词

    问题 功能是求出字符 s 与字符串t的第二公共单词(这里,假设两个字符串均由英字母和空格字符组成);若找到这样的公...

  • 求两个字符串最长公共字符串的长度

    问题描述给出两个字符串,求出两个字符串公共字符串的最大长度例如:"acbbsdef","acbesdsd"最大公共...

  • 字符串算法

    最长公共前缀 最长回文串 最长回文子序列 最长公共子串 反转单词顺序列 反转字符串 字符串转数字 IP-int互转

  • 1.给定两个字符串,求出它们之间最长公共子串 2.输入一个英文句子,翻转句子中单词的顺序,但是单词中的字符顺序不变

  • 2018-08-09

    动态规划之最长公共子序列 问题描述 给定两个字符串,求解两个字符串的最长公共子序列。比如字符串1:BDCABA;字...

  • 【python】求两个字符串的公共字串?

    题目:找出两个字符串的最长公共字串,例如字符串“abccade”与字符串“dgcadde”的最长公共子串为“cad...

  • 1143. Longest Common Subsequence

    给定两个字符串,返回两个字符串的最长公共子序列,如果不存在公共子序列,返回0。 子序列是指,是由原字符串在不改变相...

  • 动态规划:1143. 最长公共子序列(中等)

    给定两个字符串text1 和text2,返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 ,返回...

  • LeetCode 1143. 最长公共子序列

    题目 给定两个字符串 text1 和 text2,返回这两个字符串的最长 公共子序列 的长度。如果不存在公共子序列...

  • LeetCode题解:最长公共子序列

    题目描述 给定两个字符串 text1 和 text2,返回这两个字符串的最长公共子序列的长度。如果不存在 公共子序...

网友评论

      本文标题:两个字符串的第二长公共单词

      本文链接:https://www.haomeiwen.com/subject/hwxhsqtx.html