第八周项目5—— 计数的模式匹配

来源:互联网 发布:mac怎么打出顿号 编辑:程序博客网 时间:2024/04/30 15:42

问题:

/* * Copyright (c)2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名称:项目5.cpp * 作    者:秦绪龙 * 完成日期:2016年10月21日 * 版 本 号:v1.0  *问题描述:采用顺序结构存储串,编写一个算法计算指定子串在一个字符串中出现的次数,如果该子串不出现则为0。提示:无论BF模式匹配算法,还是KMP算法,都是在找到子串substr后就退出了。解决这个问题,要查找完整个字符串,并将出现的次数记下来。改造这两个算法吧。*输入描述:无 *程序输出:测试数据 *
代码:

头文件sqString.h代码:

#include <stdio.h>#define MaxSize 100             //最多的字符个数typedef struct{   char data[MaxSize];         //定义可容纳MaxSize个字符的空间    int length;                 //标记当前实际串长} SqString;void StrAssign(SqString &s,char cstr[]);    //字符串常量cstr赋给串svoid StrCopy(SqString &s,SqString t);   //串t复制给串sbool StrEqual(SqString s,SqString t); //判串相等int StrLength(SqString s);  //求串长SqString Concat(SqString s,SqString t);  //串连接SqString SubStr(SqString s,int i,int j); //求子串SqString InsStr(SqString s1,int i,SqString s2); //串插入SqString DelStr(SqString s,int i,int j) ;   //串删去SqString RepStr(SqString s,int i,int j,SqString t);     //串替换void DispStr(SqString s);   //输出串

#include <stdio.h>#include "sqString.h"int str_count(SqString s,SqString t){    int i=0,j=0,count=0;    while (i<s.length && j<t.length)    {        if (s.data[i]==t.data[j])   //继续匹配下一个字符        {            i++;                //主串和子串依次匹配下一个字符            j++;        }        else                    //主串、子串指针回溯重新开始下一次匹配        {            i=i-j+1;            //主串从下一个位置开始匹配            j=0;                //子串从头开始匹配        }        //在BF算法中,没有下面的这一部分        //这里增加一个判断,可以“捕捉”到已经产生的匹配        if (j>=t.length)        //如果j已经达到了子串的长度,产生了一个匹配        {            count++;            //匹配次数加1            i=i-j+1;            //主串从下一个位置开始继续匹配            j=0;                //子串从头开始匹配        }    }    return(count);}int main(){    SqString s,t;    StrAssign(s,"accaccacacabcacbab");    StrAssign(t,"accac");    printf("s:");    DispStr(s);    printf("t:");    DispStr(t);    printf("%d\n",str_count(s,t));    return 0;}

运行结果:
 
 
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 移动怎么办省内流量包 手机交不了话费怎么办 淘宝快递不签收怎么办 快递买家不签收怎么办 淘宝退货未收货怎么办 淘宝退衣服运费怎么办 手机流量不到账怎么办 淘宝水果坏了怎么办 用微信充值话费充成空号了怎么办 苹果id被拉黑了怎么办 苹果app不退款怎么办 合同退款不退怎么办 微信充值q币被骗怎么办 小米手机存储空间不够怎么办 小米mix2s存储空间不够怎么办 进货一直没发票怎么办 魅蓝note5卡怎么办 电话费套餐花不了怎么办 墙和床头有间缝怎么办 床板里有虫子怎么办 松木床板味道大怎么办 寝室床板有虫子怎么办 胶合板当床板有气味怎么办 淘宝食品有问题怎么办 淘宝买东西碎了怎么办 被淘宝商家骚扰怎么办 闲鱼被别人拉黑怎么办 三无工厂抓到怎么办 淘宝买东西卖家不发货怎么办 打假人异地起诉怎么办 卖家拒绝发货怎么办 千牛发货收费怎么办 淘宝购物想退货怎么办 天猫超市发货怎么办 驾校退款乱收怎么办 驾校退款有疑问怎么办 物流消息不更新怎么办 退款了商家发货怎么办 打是12345没有用怎么办 天猫不肯发货怎么办 京东店家发错货怎么办