sqString.h

#ifndef SqString_H_INCLUDED
#define SqString_H_INCLUDED#define MaxSize 100             //最多的字符个数
typedef struct
{   char data[MaxSize];         //定义可容纳MaxSize个字符的空间int length;                 //标记当前实际串长
} SqString;void StrAssign(SqString &s,char cstr[]);    //字符串常量cstr赋给串s
void StrCopy(SqString &s,SqString t);   //串t复制给串s
bool 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);   //输出串#endif // SqString_H_INCLUDED

sqString.cpp

#include <stdio.h>
#include <malloc.h>
#include "SqString.h"
void StrAssign(SqString &s,char cstr[]) //s为引用型参数
{   int i;for (i=0;cstr[i]!='\0';i++)s.data[i]=cstr[i];s.length=i;
}
void StrCopy(SqString &s,SqString t)    //s为引用型参数
{   int i;for (i=0;i<t.length;i++)s.data[i]=t.data[i];s.length=t.length;
}
bool StrEqual(SqString s,SqString t)
{   bool same=true;int i;if (s.length!=t.length)             //长度不相等时返回0same=false;elsefor (i=0;i<s.length;i++)if (s.data[i]!=t.data[i])   //有一个对应字符不相同时返回0{   same=false;break;}return same;
}
int StrLength(SqString s)
{return s.length;
}
SqString Concat(SqString s,SqString t)
{   SqString str;int i;str.length=s.length+t.length;for (i=0;i<s.length;i++)    //将s.data[0..s.length-1]复制到strstr.data[i]=s.data[i];for (i=0;i<t.length;i++)    //将t.data[0..t.length-1]复制到strstr.data[s.length+i]=t.data[i];return str;
}
SqString SubStr(SqString s,int i,int j)
{   SqString str;int k;str.length=0;if (i<=0 || i>s.length || j<0 || i+j-1>s.length)return str;                 //参数不正确时返回空串for (k=i-1;k<i+j-1;k++)         //将s.data[i..i+j]复制到strstr.data[k-i+1]=s.data[k];str.length=j;return str;
}
SqString InsStr(SqString s1,int i,SqString s2)
{   int j;SqString str;str.length=0;if (i<=0 || i>s1.length+1)  //参数不正确时返回空串return str;for (j=0;j<i-1;j++)             //将s1.data[0..i-2]复制到strstr.data[j]=s1.data[j];for (j=0;j<s2.length;j++)       //将s2.data[0..s2.length-1]复制到strstr.data[i+j-1]=s2.data[j];for (j=i-1;j<s1.length;j++)     //将s1.data[i-1..s1.length-1]复制到strstr.data[s2.length+j]=s1.data[j];str.length=s1.length+s2.length;return str;
}
SqString DelStr(SqString s,int i,int j)
{   int k;SqString str;str.length=0;if (i<=0 || i>s.length || i+j>s.length+1) //参数不正确时返回空串return str;for (k=0;k<i-1;k++)             //将s.data[0..i-2]复制到strstr.data[k]=s.data[k];for (k=i+j-1;k<s.length;k++)    //将s.data[i+j-1..s.length-1]复制到strstr.data[k-j]=s.data[k];str.length=s.length-j;return str;
}
SqString RepStr(SqString s,int i,int j,SqString t)
{   int k;SqString str;str.length=0;if (i<=0 || i>s.length || i+j-1>s.length) //参数不正确时返回空串return str;for (k=0;k<i-1;k++)             //将s.data[0..i-2]复制到strstr.data[k]=s.data[k];for (k=0;k<t.length;k++)        //将t.data[0..t.length-1]复制到strstr.data[i+k-1]=t.data[k];for (k=i+j-1;k<s.length;k++)    //将s.data[i+j-1..s.length-1]复制到strstr.data[t.length+k-j]=s.data[k];str.length=s.length-j+t.length;return str;
}
void DispStr(SqString s)
{   int i;if (s.length>0){   for (i=0;i<s.length;i++)printf("%c",s.data[i]);printf("\n");}
}

main.cpp

#include <stdio.h>
#include "sqString.h"
void GetNext(SqString t,int next[])  /*由模式串t求出next值*/
{int j,k;j=0;k=-1;next[0]=-1;while (j<t.length-1){if (k==-1 || t.data[j]==t.data[k])  /*k为-1或比较的字符相等时*/{j++;k++;next[j]=k;}elsek=next[k];}
}
int KMPIndex(SqString s,SqString t)  /*KMP算法*/
{int next[MaxSize],i=0,j=0;GetNext(t,next);while (i<s.length && j<t.length){if (j==-1 || s.data[i]==t.data[j]){i++;j++;            /*i,j各增1*/}else j=next[j];         /*i不变,j后退*/}if (j>=t.length)return(i-t.length);         /*返回匹配模式串的首字符下标*/elsereturn(-1);             /*返回不匹配标志*/
}
int main()
{SqString s,t;StrAssign(s,"ababcabcacbab");StrAssign(t,"abcac");printf("s:");DispStr(s);printf("t:");DispStr(t);printf("位置:%d\n",KMPIndex(s,t));return 0;
}

第八周项目实践6 KMP算法(串的模式匹配)相关推荐

  1. 第八周项目实践2 建立连串算法库

    liString.h #ifndef LISTRING_H_INCLUDED #define LISTRING_H_INCLUDEDtypedef struct snode {char data;st ...

  2. 第八周项目实践1 建立顺序串的算法库

    SqString .h #ifndef SqString_H_INCLUDED #define SqString_H_INCLUDED#define MaxSize 100 //最多的字符个数 typ ...

  3. 数据结构上机实践第八周项目9-广义表算法库及应用

    广义表算法库及应用 为了丰富算法库,以应对各类工程的需要,本次实践将进行广义表算法库的建立以及应用. 项目要求一: 建立广义表算法库,包括:  ① 头文glist.h,定义数据类型,声明函数:  ② ...

  4. 第十周项目实践1 二叉树算法验证

    #ifndef BTREE_H_INCLUDED #define BTREE_H_INCLUDED #define MaxSize 100 typedef char ElemType; typedef ...

  5. 第7周项目实践 1 队列算法库的建立

    sqqueue.cpp#include <stdio.h> #include <malloc.h> #include "sqqueue.h" void In ...

  6. 数据结构上机实践第八周项目2- 建立链串的算法库

    建立链串的算法库 一般每一种数据结构都不会局限于在连续空间内的存取,那我们的串自然也不反常,本次实践将建立链串的算法库,应用于有需求的工程当中,提高程序的容错性. 本次实践依然会用到多文件组织工程的建 ...

  7. 数据结构上机实践第八周项目1- 建立顺序串的算法库

    建立顺序串的算法库 本次实践将建立顺序串的算法库,这样可以方便的将此算法运用于我们的所需的工程中,简化操作. 本次实践将用到多文件组织工程的建立,建立方法可以点击此处参照.(工程环境:Visual C ...

  8. 数据结构上机实践第11周项目3 - 图遍历算法实现

    图遍历算法实现 本次实践将运用图结构基本算法库,进行遍历操作的实现,本次实践到的算法库点击此处参考.(编译环境:VC++6.0) 1.深度优先遍历--DFS 测试用图: 测试时用的图是,可以使用其他类 ...

  9. 数据结构上机实践第八周项目7—对称矩阵的压缩存储及基本运算

    对称矩阵的压缩存储及基本运算 贺老师的慕课当中,给我们拓展了这样的知识. 所以,本次的项目实践要求如下: 用压缩形式存储对称矩阵,实现下面的操作并测试 void Init(int *&b);/ ...

最新文章

  1. 【java 性能优化实战】1 理论分析:性能优化,有哪些衡量指标、性能优化的技术手段
  2. 中国移动手机网络私有网络连接问题解决办法
  3. mysql natural join用法_MySQL NATURAL JOIN
  4. Ajax爬取豆瓣电影目录(Python)
  5. Tomcat架构与原理
  6. C++ lower_bound和upper_bound的区别
  7. tomcat-maven插件热部署(简洁版)
  8. 吴恩达神经网络和深度学习-学习笔记-32-卷积神经网络示例
  9. Centos7.2下安装redis通用键值命令
  10. 怎样提高团队管理能力7
  11. 案例4-4 Windows消息队列 (25 分)(优先队列的优先级设定)
  12. Android开发笔记(成长轨迹)
  13. html语言基本标记实训,HTML静态网页设计实训.ppt
  14. java算法:复合数据结构
  15. 七成知识分子走在过劳死边缘
  16. 为什么说90%以上的创业者都在亏钱?
  17. 微软Azure动手实验营4月课程预告
  18. JAVA核心知识点--JDK1.8中的日期处理
  19. .playground文件_部署可教学机器:Circuit Playground Express,Arduino,P5.js,TinyUSB
  20. 梁漱溟: 思考问题的八层境界

热门文章

  1. android edittext 限制文本框输入的长度和提示信息
  2. Android N Display Size
  3. 计算机文件夹报告范文,2020年计算机实验报告打印(例文).docx
  4. React状态管理大乱斗,横向对比Dva,Rematch,Mirror
  5. 【Unity】Protobuf的使用与常见问题
  6. lustre1.6.5+drbd主备切换
  7. Rhino脚本引擎技术介绍
  8. ORA-01940,删除某用户的所有对象
  9. tab与list配合使用
  10. 【正一专栏】保护孩子人人有责-评南京猥亵女童案