关于#藏头诗#的问题,如何解决?

读过《水浒传》的人应该都熟悉这一首藏头诗:
芦花丛中一扁舟,
俊杰俄从此地游,
义士若能知此理,
反躬难逃可无忧。
这是军师吴用为卢俊义写的,巧妙地把“卢俊义反”四个字暗藏于四句之首,最终把他逼上梁山。
小图灵觉得这样的藏头诗太有意思了,他决定跟同学们写一首英文的藏头诗,规则是这样的:同学们会说一句话,其中共包括n个单词,依次取这些单词的首字母,组成一个长度是n的新单词,如果这个新单词在这句话出现过,则输出yes,否则输出no。

每个单词之间有多少个空格?是否区分大小写?你得说明白一些
先拆分所有单词,然后将每行第一个字母构成一个单词,在所有单词中搜索这个单词

#include <iostream>
#include <string>
#include <vector>
using namespace std;

// 使用字符分割
void Stringsplit(const string& str, const char split, vector<string>& res)
{
    if (str == "")        return;
    //在字符串末尾也加入分隔符,方便截取最后一段
    string strs = str + split;
    size_t pos = strs.find(split);
  
    // 若找不到内容则字符串搜索函数返回 npos
    while (pos != strs.npos)
    {
        string temp = strs.substr(0, pos);
        res.push_back(temp);
        //去掉已分割的字符串,在剩下的字符串中进行分割
        while(pos < strs.size()-1)
        {
            if(strs[pos+1] == split)
                pos++;
            else
                break;
        }
        strs = strs.substr(pos + 1, strs.size());

        pos = strs.find(split);
    }
}

int main()
{
    string s;
    getline(cin,s);
    s.erase(0,s.find_first_not_of(' '));
    s.erase(s.find_last_not_of(' ')+1);
    vector<string> vs;
    Stringsplit(s,' ',vs);
    string ns;
    int i;
    for(i=0;i<vs.size();i++)
        ns += vs[i][0];
    for(i=0;i<vs.size();i++)
        if(ns == vs[i])
            break;
    if(i==vs.size())
        cout<<"no";
    else
        cout<<"yes";
    
    return 0;
}