C++ 判断一个大字符串里出现一个小字符串的次数 string对象

C++ 如何判断一个大字符串里出现一个小字符串的次数 用string对象的自带函数有吗

阅读 9.7k
3 个回答

封装一下 find 方法即可。

随手写的示例代码,仅供参考:

cppstd::string str("abcabdabcdsdabcds");

auto occurrences = [&str](const std::string &dest) {
    size_t pos, pre = 0, count = 0;
    while ( (pos = str.find(dest, pre)) != std::string::npos ) {
        ++count;
        pre = pos + 1;
    }
    return count;
};

std::cout << occurrences("abc") << std::endl;

写个例子把 比如abcabcabcdsadg里出现abc的次数

使用KMP算法或者sunday算法都可以处理

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进