当前位置: 首页 > article >正文

【头歌实训:利用kmp算法求子串在主串中不重叠出现的次数】

头歌实训:利用kmp算法求子串在主串中不重叠出现的次数

文章目录

  • 任务描述
  • 编程要求
  • 测试说明
    • 输入格式
    • 输出格式
    • 样例输入1
    • 样例输出1
    • 样例输入2
    • 样例输出2
  • 源代码:

任务描述

本关任务:编写一个程序,利用kmp算法求子串在主串中不重叠出现的次数。

实验目的:深入掌握KMP算法的应用。
实验内容:编写一个程序,利用KMP算法求子串t在主串s中出现的次数,例如:s=“aabbdaabbde”,t=“aabbd”,t在s中出现2次;再例如:s=“aaaaa”,t=“aa”,t在s中出现2次。
实验工具:本关提供顺序串SqString的基本运算及其实现(在头文件sqstring.h中);您也可以直接使用C++ STL提供的string容器。

编程要求

根据提示,在右侧编辑器补充完成代码,计算并输出字符串t在字符串s中不重叠出现的次数。

测试说明

平台会对你编写的代码进行测试:

输入格式

输入包括2行。
第一行为字符串s,长度不超过106
第二行为字符串t,长度不超过106

输出格式

在一行中输出t在s中出现的次数。

样例输入1

aaaaa
aa

样例输出1

2

样例输入2

aabbdaabbde
aabbd

样例输出2

2

开始你的任务吧,祝你成功!

源代码:

#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <string>       //C++ STL之string容器
using namespace std;

#include "sqstring.h" //包含顺序串SqString基本运算算法

//利用KMP算法求t在s中出现的次数
int Count(string s, string t); 

//利用KMP算法求t在s中出现的次数
//int Count(char* s, char* t); 

//利用KMP算法求t在s中出现的次数
//int Count(SqString s, SqString t); 

/**
 * 说明:任选上面三个函数中的一个进行实现。
 */

//请在下面编写代码
int main()
{
    string s, t;
    cin >> s >> t;
    //cout << s << " " << t << endl;
    int cnt = Count(s, t);
    cout << cnt << endl;
    return 0;
}

int Count(string s, string t)
{
    int next[t.length()], j = 0, k = -1, i, cnt = 0; //next数组用于遍历时字符串t的下标回溯,j用于遍历字符串t,i用于便利字符串s,k用于给next数组赋值,cnt用于记录子字符串出现的次数
    next[0] = -1;   //将第一个next数组的下标置为-1
    while(j < t.length() - 1)   //获得next数组
    {
        if(k == -1 || t[j] == t[k])
        {
            j++;k++;
            next[j] = k;
        }
        else
        {
            k = next[k];
        }
    }
    i = j = 0;  //初始化两个下标
    while(i < s.length())   //通过while循环获得出现次数
    {
        if(j == -1 || s[i] == t[j])
        {
            i++;j++;
        }
        else
        {
            j = next[j];
        }
        if(j == t.length()) //当匹配成功时计数器++并且回溯j到0
        {
            cnt++;
            j = 0;
        }
    }
    return cnt; //返回出现次数
}


http://www.kler.cn/a/406256.html

相关文章:

  • html5复习二
  • 【代码随想录day38】【C++复健】322. 零钱兑换;279.完全平方数;139.单词拆分;卡码网56. 携带矿石资源
  • SQL注入的那些面试题总结
  • 格式化输入输出【专辑优质版】
  • 杰理-gpadc
  • reactflow 中 useStoreApi 模块作用
  • 使用 前端技术 创建 QR 码生成器 API1
  • HTML详解(1)
  • 『 Linux 』网络层 - IP协议(一)
  • wireshark网络安全流量分析基础
  • 量化交易系统开发-实时行情自动化交易-3.4.3.4.期货衍生数据
  • 沥川的算法学习笔记:基础算法(3)----高精度算法
  • C++学习 - 03(单例模式)
  • 蓝队技能-应急响应篇Rookit后门进程提取网络发现隐藏技术Linux杀毒OpenArk
  • MATLAB和C++及Python流式细胞术
  • display: none和visibility: hidden的区别
  • json数据四大加载方式
  • LeetCode:700. 二叉搜索树中的搜索
  • Lucene(2):Springboot整合全文检索引擎TermInSetQuery应用实例附源码
  • PVE的优化与温度监控(二)—无法识别移动硬盘S.M.A.R.T信息的思考并解决
  • CSS布局学习2
  • 深度学习:计算卷积神经网络中输出特征图尺寸的关键公式
  • 深度剖析Linux进程控制
  • VsCode 插件推荐(个人常用)
  • 【ArcGISPro】根据yaml构建原始Pro的conda环境
  • 【高阶数据结构】LRU Cache