计算字符串中子串出现的次数

复制代码
#include <stdio.h>

int my_strnum(const char *str1, const char *str2)
{
    int num = 0, str1_len = 0, str2_len = 0;
    const char *temp1 = str1;
    const char *temp2 = str2;

    while (*temp1++)
    {
        str1_len++;
    }

    while (*temp2++)
    {
        str2_len++;
    }

    for (int i = 0; i < str1_len-str2_len+1; i++)
    {
        for (int j = 0; j < str2_len; j++)
        {
            if (*(str1+i+j) != *(str2+j))
            {
                break;
            }

            if (*(str1+i+j) == *(str2+j) && j == str2_len-1)
            {
                num++;
            }
        }
    }

    return num;
}

int main(int argc, char *argv[])
{
    char *str1 = "af12312afsaf12fasf12312gds123";
    char *str2 = "123";

    printf("str1 含 %d 个 str2\n", my_strnum(str1, str2));

    return 1;
}
复制代码

 

posted @   jason8826  阅读(94)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
点击右上角即可分享
微信分享提示