在 std::string 中,是否可以在不使用循环的情况下找到一组字符串中的第一个?
例如:
std::string str("aaa bbb ccc ddd eee fff ggg");
std::vector<std::string> vs;
vs.push_back("ccc");
vs.push_back("fff");
size_t pos = 0
pos = str.find(vs, pos); //< pseudo code
谢谢!
最佳答案
您可以将字符串(使用字符串流)拆分为一个 vector ,然后将 std::find_first_of
与四个迭代器一起使用。
这是一个完整的代码示例
#include <iostream>
#include <string>
#include <algorithm>
#include <sstream>
#include <vector>
#include <iterator>
using namespace std;
int main(void)
{
string str("aaa bbb ccc ddd eee fff ggg");
vector<string> vs;
vs.push_back("ccc");
vs.push_back("fff");
vector<string> scheck;
istringstream instr(str);
copy(istream_iterator<string>(instr),
istream_iterator<string>(),
back_inserter(scheck));
vector<string>::iterator it = find_first_of (scheck.begin(), scheck.end(), vs.begin(), vs.end());
if (it != scheck.end())
cout << "first match is: " << *it << endl;
return 0;
}
关于c++ - 在 std::string 中,是否可以在不使用循环的情况下找到一组字符串中的第一个?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4334057/