计算字符串向量中字符串的出现次数

时间:2016-07-09 17:15:19

标签: c++ string vector count

我的要求是计算字符串向量内字符串的出现次数。要搜索的字符串是向量的第0个索引。

我正在使用来自count标头的内置algorithm函数,但得到了一个奇怪的编译错误,我无法解决。

我的代码:

vector<string> a={"abc", "def", "abc"};
int cnt = count(a.begin(), a.end(), a[0]);

编译错误信息是:

count(std::vector<std::basic_string<char> >)':
error: no matching function for call to std::vector<std::basic_string<char> >::iterator, std::vector<std::basic_string<char> >::iterator, __gnu_cxx::__alloc_traits<std::allocator<std::basic_string<char> > >::value_type&)'
  int cnt = count(a.begin(), a.end(), a[0]);

有任何帮助吗?这是什么问题?

1 个答案:

答案 0 :(得分:0)

您提到了算法库,但请确保添加了#include <algorithm>

使用您的算法,它在代码

上运行良好
#include <iostream>     // std::cout
#include <algorithm>    // std::count
#include <vector>       // std::vector
#include <string>       // std::vector

using namespace std;

int main () {

  // counting elements in container:
  vector<string> a {"abc", "def", "abc"};
  int cnt = count(a.begin(), a.end(), a.at(0));
  std::cout << a.at(0) << " " << cnt  << " times.\n";

  return 0;
}

编译器标志:

-------------- Build: Debug in test (compiler: GNU GCC Compiler)---------------

mingw32-g++.exe -Wall -fexceptions -g -Weffc++ -std=c++14

此外,我的解决方案可能对您有用

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

using namespace std;

int main()
{
    vector<string> stringList;
    stringList.push_back("abc");
    stringList.push_back("def");
    stringList.push_back("111 abc");
    string searchWord ("abc");
    int searchWordSize = searchWord.size();
    int count = 0;

    for (vector<string>::iterator iter = stringList.begin(); iter != stringList.end(); ++iter) {
        for (size_t pos = 0; pos < (*iter).length(); pos += searchWordSize) {
            pos = (*iter).find(searchWord, pos);
            if (pos != string::npos) ++count;
            else break;
        }
    }

    cout << "Count: " << count << endl;

    return 0;
}