串、串的模式匹配算法(子串查找)BF算法、KMP算法

简介: 串、串的模式匹配算法(子串查找)BF算法、KMP算法

串的定长顺序存储

#define MAXSTRLEN 255,//超出这个长度则超出部分被舍去,称为截断

串的模式匹配:

串的定义:0个或多个字符组成的有限序列

S = 'a1a2a3…….an '

n = 0时为空串

串的顺序存储结构:字符数组,串的长度就是数组末尾‘\0'前面的字符个数

数组需在定义时确定长度,有局限性

数组的最大长度

二:串的堆分配存储表示

typedef struct {

char *ch;

//若是非空串,则按串长分配存储区

//否则ch为空

int length; //串长度

}HString;

系统利用函数mallloc和free进行串值空间的动态分配,由此产生的新串

其实是系统先为新生成的串分配一个存储空间,然后进行串的复制(这是C语言的串类型

的存储方式)

三、串的块链存储方式

 1 #define CHUNKSIZE 80
 2 typedef struct Chunk{    //结点结构
 3 char ch[CHUNKSIZE];
 4 struct Chunk* next;
 5 }Chunk;
 6 
 7 typedef struct {    //串的链表结构
 8 Chunk*head, *tail;    //串的头和尾指针
 9 int curlen;    //串的当前长度
10 }LString;

data | 指针

1byte 4byte

1/5存储密度

4.3串的模式匹配算法(子串查找)

BF算法:朴素算法

 1 int Index(SString S, SString T, int pos)
 2 {
 3 i = pos; j = 1;
 4 while(i <= s[0] && j <= T[0])
 5 {
 6 if(s[i] == T[j])
 7 {
 8 ++i;
 9 ++j;
10 }
11 else    
12 {
13 i = i - j + 2;    //i指针回溯
14 j = 1;    //指针后退重新开始匹配
15 }
16 if(j > T[0])
17 return i - T[0];
18 else
19 return 0;
20 }
21 }
 1 int Index(SString S, SString T, int pos)
 2 {
 3 for(i = pos; i <= S[0] - T[0]; i++)
 4 {
 5 int k = i;
 6 for(j = 1; j <= T[0]; j++)
 7 {
 8 if(S[i] == T[j])
 9 {
10 i++;
11 j++;
12 }
13 else
14 {
15 i = k;
16 break;
17 }
18 }
19 if(j > T[0])
20 return i - T[0];
21 else
22 return 0;
23 }
24 }

二、首尾匹配算法

先比较模式串的第一个字符

再比较模式串的最后一个字符

最后比较比较模式串中第二个得到倒数第二个之间的字符

算法复杂度和第一种一样O((n-m+1)m)

三、KMP算法

时间复杂度可达到O(m+n)

 1 int Index(SString S, SString T, int pos)
 2 {
 3 i = pos; j = 1;
 4 while(i <= s[0] && j <= T[0])
 5 {    
 6 //j == 0说明上次比较时第一个字符就不等next[1] = 0
 7 if(j == 0 || s[i] == T[j])
 8 {
 9 ++i;
10 ++j;
11 }
12 else    
13 {
14 j = next[j];    //i不用指针回溯
15 //j指针后退到next[j]重新开始匹配
16 }
17 }
18 if(j > T[0])
19 return i - T[0];
20 else
21 return 0;
22 
23 }

求next函数值

已知:next[1] = 0;

假设:next[j] = k; 又因为T[k] = T[j]

则next[j+ 1] = k + 1;

ruo T[j] != T[k]

则需要回朔,检查T[j] = T[?]

这是几上也是一个匹配过程,不同在于:主串和模式串是同一个串

 1 void get_next(SString &T, int &next[])//求模式串T的next函数值并存入数组next
 2 {
 3 i = 1; next[1] = 0;
 4 j = 0;
 5 while(i < T[0])
 6 {
 7 if(j == 0 || T[i] = T[j])
 8 {
 9 ++i;
10 ++j;
11 next[i] = j;
12 }
13 
14 else
15 j = next[j];
16 if(
17 }
18 
19 }


特殊情况

S = ‘aaabaaabaaabaaabaaab'

T = 'aaaab'

next[j] = 01234修正后00004

 1 void get_next(SString &T, int &next[])//求模式串T的next函数值并存入数组next
 2 {
 3 i = 1; next[1] = 0;
 4 j = 0;
 5 while(i < T[0])
 6 {
 7 if(j == 0 || T[i] = T[j])
 8 {
 9 ++i;
10 ++j;
11 if(T[i] != T[j])
12 nextval [i] = j;
13 else
14 nextval[i] = next[j];
15 }
16 
17 else
18 j = nextval[j];
19 if(
20 }
21 
22 }


相关文章
|
1月前
|
算法 搜索推荐
如何用CRDT算法颠覆文档协作模式?
在局域网环境下,高效文档协同编辑面临版本冲突等核心技术挑战,影响协作效率和成果质量。为解决此问题,可采用基于CRDT的算法,允许多用户无冲突实时编辑;或将协同操作模块化,通过任务看板优化协作流程,减少冲突,提高团队效率。未来,局域网协同编辑将更加场景化与个性化,深入探索组织协作文化。
|
5月前
|
算法
【算法】滑动窗口——最小覆盖子串
【算法】滑动窗口——最小覆盖子串
|
3月前
|
前端开发 算法 JavaScript
无界SaaS模式深度解析:算力算法、链接力、数据确权制度
私域电商的无界SaaS模式涉及后端开发、前端开发、数据库设计、API接口、区块链技术、支付和身份验证系统等多个技术领域。本文通过简化框架和示例代码,指导如何将核心功能转化为技术实现,涵盖用户管理、企业店铺管理、数据流量管理等关键环节。
|
3月前
|
算法
第四章 KMP算法理论基础
第四章 KMP算法理论基础
29 0
|
3月前
|
算法
KMP算法
KMP算法
48 0
|
5月前
|
算法 C++
A : DS串应用–KMP算法
这篇文章提供了KMP算法的C++实现,包括计算模式串的next数组和在主串中查找模式串位置的函数,用于演示KMP算法的基本应用。
|
5月前
|
算法
KMP算法
KMP算法
40 0
|
5月前
|
算法 容器
【算法】滑动窗口——串联所有单词的子串
【算法】滑动窗口——串联所有单词的子串
|
6月前
|
算法 Java
KMP算法详解及其在字符串匹配中的应用
KMP算法详解及其在字符串匹配中的应用
|
1天前
|
机器学习/深度学习 数据采集 算法
基于GA遗传优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真
本项目基于MATLAB2022a实现时间序列预测,采用CNN-GRU-SAM网络结构。卷积层提取局部特征,GRU层处理长期依赖,自注意力机制捕捉全局特征。完整代码含中文注释和操作视频,运行效果无水印展示。算法通过数据归一化、种群初始化、适应度计算、个体更新等步骤优化网络参数,最终输出预测结果。适用于金融市场、气象预报等领域。
基于GA遗传优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真

热门文章

最新文章