C++ 判断一个大字符串里出现一个小字符串的次数 string对象
怪我咯
怪我咯 2017-04-17 11:46:58
0
3
560

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

怪我咯
怪我咯

走同样的路,发现不同的人生

全員に返信(3)
Peter_Zhu

封装一下 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;
いいねを押す +0
洪涛

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

いいねを押す +0
刘奇

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

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート