2024重生之回溯数据结构与算法系列学习(12)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丟脸好嘛?】

欢迎各位彦祖与热巴畅游本人专栏与博客

你的三连是我最大的动力

以下图片仅代表专栏特色 [点击箭头指向的专栏名即可闪现]

专栏跑道一
 ➡️ MYSQL REDIS Advance operation


专栏跑道二
➡️ 24 Network Security -LJS 

​ 

专栏跑道三

➡️HCIP;H3C-SE;CCIP——LJS[华为、华三、思科高级网络]

专栏跑道四
➡️RHCE-LJS[Linux高端骚操作实战篇]

专栏跑道五

➡️数据结构与算法[考研+实际工作应用+C程序设计]

专栏跑道六 

➡️RHCSA-LJS[Linux初级及进阶骚技能]

上节回顾icon-default.png?t=O83Ahttps://netsecur-cloud-ljs.blog.csdn.net/article/details/142748886

目录

欢迎各位彦祖与热巴畅游本人专栏与博客

你的三连是我最大的动力

以下图片仅代表专栏特色 [点击箭头指向的专栏名即可闪现]

专栏跑道一 ➡️ MYSQL REDIS Advance operation

专栏跑道二➡️ 24 Network Security -LJS 

专栏跑道三

➡️HCIP;H3C-SE;CCIP——LJS[华为、华三、思科高级网络]

专栏跑道四➡️RHCE-LJS[Linux高端骚操作实战篇]​编辑​

专栏跑道五

➡️数据结构与算法[考研+实际工作应用+C程序设计]

专栏跑道六 

➡️RHCSA-LJS[Linux初级及进阶骚技能]

上节回顾https://netsecur-cloud-ljs.blog.csdn.net/article/details/142748886

数据结构与算法系列学习之串

1.串的定义和基本操作

1.1定义:

1.2串的基本操作

1.3字符集编码:

2.串的储存结构

2.1顺序存储:

代码实现: 

 2.2链式存储

代码实现: 

3.基本操作的实现(使用第四种方案):

基本操作代码实现[方案4]:

4.朴素模式匹配算法

4.1字符串模式匹配:

4.2朴素模式匹配算法(两种实现方法):

朴素模式匹配算法代码实现:

5.KMP算法

5.1KMP算法的概念

5.2KMP算法的优点

​编辑 5.3KMP算法代码实现:

5.4KMP算法之求next数组

5.4.1求next数组代码实现 [含图解]

5.4.1next数组的作用:

5.5KMP算法之求nextval数组

定义:

 nextval数组的求法:

求nextval数组代码实现[此处本人理解可能有点小问题,但是问题不大;理论任然成立]

数据结构与算法系列学习之串

1.串的定义和基本操作

1.1定义:

  • 串,即字符串(String)是由零个或多个字符组成的有限序列。一般记为S = ‘a1a2······an' (n ≥0)
  • 其中,S是串名,单引号括起来的字符序列是串的值;ai可以是字母、数字或其他字符;串中字符的个数n称为串的长度。n = 0时的串称为空串(用∅表示)。
  • 有的地方用双引号(如Java、C),有的地方用单引号(如Python)
  • 例如:S=”HelloWorld!”T=‘iPhone 14 Pro Max?’
  • 子串:串中任意个连续的字符组成的子序列。Eg:’iPhone’,’Pro M’是串T的子串
  • 主串:包含子串的串。Eg:T是子串’iPhone’的主串
  • 字符在主串中的位置:字符在串中的序号。Eg:’1’在T中的位置是8(第一次出现)
  • 子串在主串中的位置子串的第一个字符在主串中的位置。Eg:’14Pro’在T中的位置为8
  • 每个空格字符占1B,不是空串
  • 串的位序从1开始而不是从0开始
  • 串是一种特殊的线性表,数据元素之间线性关系
  • 串的数据对象限定为字符集(如中文字符、英文字符、数字字符、标点字符等)
  • 串的基本操作,如增删改查等通常以子串为操作对象,因为人类的语言通常要多个字符组成的序列才有现实意义

1.2串的基本操作

假设有串 T = ''S = 'iPhone 14 Pro Max?'W = 'Pro'

  • StrAssign(&T, chars): 赋值操作,把串T赋值为chars;
  • StrCopy(&T, S): 复制操作,把串S复制得到串T
  • StrEmpty(S): 判空操作,若S为空串,则返回TRUE,否则返回False;
  • StrLength(S): 求串长,返回串S的元素个数;
  • ClearString(&S): 清空操作,将S清为空串;
  • DestroyString(&S): 销毁串,将串S销毁——回收存储空间;
  • Concat(&T, S1, S2): 串联联接,用T返回由S1和S2联接而成的新串———可能会导致存储空间的扩展;
  • 例:
    Concat(&T, S, W)T = ‘iPhone 14 Pro Max?Pro’
    
  • SubString(&Sub, S, pos, len): 求子串,用Sub返回串S的第pos个字符起长度为len的子串;
SubString(&T, S, 4, 6)T = ‘one 14’
  • Index(S, T): 定位操作,若主串S中存在与串T值相同的子串,则返回它再主串S中第一次出现的位置,否则函数值为0;
  • StrCompare(S, T): 串的比较操作,参照英文词典排序方式;若S > T,返回值>0; S = T,返回值=0 (需要两个串完全相同) ; S < T,返回值<0;

1.3字符集编码:

  • 任何数据存到计算机中一定是二进制数。
  • 需要确定一个字符和二进制数的对应规则这就是“编码”
  • “字符集”:英文字符,ASCII字符集,中英文,Unicode字符集
  • 基于同一个字符集,可以有多种编码方案,如:UTF-8,UTF-16
  • 注:采用不同的编码方式,每个字符所占空间不同,考研中只需默认每个字符占1B即可

2.串的储存结构

2.1顺序存储:

代码实现: 

#define MAXLEN 255   //预定义最大串长为255typedef struct{char ch[MAXLEN];   //静态数组实现(定长顺序存储)//每个分量存储一个字符//每个char字符占1Bint length;        //串的实际长度
}SString;
  • 方案一:一个数组来储存字符,一个int变量length储存实际长度
  • 方案二:数组的ch[0]来充当length,优点:字符的位序和数组下标相同
  • 方案三:没有Length变量,以字符’\0’表示结尾(对应ASCII码的0),缺点:获取字符串长度需要遍历,时间复杂度高
  • 方案四:数组的ch[0]废弃不用,从看开始储存字符,外加一个int变量length储存实际长度

 2.2链式存储

代码实现: 

typedef struct StringNode{char ch;           //每个结点存1个字符struct StringNode *next;
}StringNode, * String;问题:存储密度低,每个字符1B,每个指针4B;
解决方案:每一个链表的结点存储多个字符——每个结点称为块——块链结构typedef struct StringNode{char ch[4];           //每个结点存多个个字符struct StringNode *next;
}StringNode, * String;

  • 推荐使用第二种方式,存储密度较高,ch数组未必一定是4个字符,也可以比4多

 

3.基本操作的实现(使用第四种方案):

基本操作代码实现[方案4]:

#define MAXLEN 255typedef struct{char ch[MAXLEN];   int length;       
}SString;// 1. 求子串
bool SubString(SString &Sub, SString S, int pos, int len){//子串范围越界if (pos+len-1 > S.length)return false;for (int i=pos; i<pos+len; i++)Sub.cn[i-pos+1] = S.ch[i];Sub.length = len;return true;
}// 2. 比较两个串的大小
int StrCompare(SString S, SString T){for (int i; i<S.length && i<T.length; i++){if(S.ch[i] != T.ch[i])return S.ch[i] - T.ch[i];}//扫描过的所有字符都相同,则长度长的串更大return S.length - T.length;
}// 3. 定位操作
int Index(SString S, SString T){int i=1;n = StrLength(S);m = StrLength(T);SString sub;        //用于暂存子串while(i<=n-m+1){SubString(Sub,S,i,m);if(StrCompare(Sub,T)!=0)++i;else return i;    // 返回子串在主串中的位置}return 0;            //S中不存在与T相等的子串
}

4.朴素模式匹配算法

4.1字符串模式匹配:

  • 在主串中找到与模式串相同的子串,并返回其所在位置。

  • 子串:主串的一部分,一定存在

  • 模式串:不一定能在主串中找到

  • 要掌握朴素模式匹配算法、KMP算法两种方法

4.2朴素模式匹配算法(两种实现方法):

  • 将主串中所有长度为m的子串依次与模式串对比,直到找到一个完全匹配的子串,或所有的子串都不匹配为止。
  • 主串长度为n,模式串长度为 m,最多对比 n-m+1 个子串
  • 上节讲的index定位操作就是朴素模式匹配算法中其中一种实现方法
  • 也可以使用两个指针i和j来进行匹配。若当前子串匹配失败,则主串指针 i 指向下一个子串的第一个位置,模式串指针 j 回到模式串的第一个位置,即i = i - j + 2; j = 1;
  • 若 j > T.length,则当前子串匹配成功,返回当前子串第一个字符的位置即i - T.length

设主串长度为 n,模式串长度为 m,则最坏时间复杂度 = O(n*m),最好时间复杂度 = O(n)
朴素模式匹配算法代码实现:
int Index(SString S, SString T){int i=1;                //扫描主串Sint j=1;                //扫描模式串Twhile(i<=S.length && j<=T.length){if(S.ch[i] == T.ch[j]){++i;++j;             //继续比较后继字符}else{i = i-j+2;j=1;             //指针后退重新开始匹配}}if(j>T.length)return i-T.length;elsereturn 0;
}

5.KMP算法

5.1KMP算法的概念

  • 由D.E.Knuth,J.H.Morris和V.R.Pratt提出,因此称为 KMP算法

  • 是对朴素模式匹配算法的优化

  • 优化的原理就是减少了i指针的回溯,通过已经计算好的next指针,提高算法的整体运行效率

next数组记录了当第几个元素匹配失败时候,j的取值例如:

  • 对于模式串 T = ‘abaabc’
  • 当第6个元素匹配失败时,可令主串指针 i 不变,模式串指针 j=3
  • 当第5个元素匹配失败时,可令主串指针 i 不变,模式串指针 j=2
  • 当第4个元素匹配失败时,可令主串指针 i 不变,模式串指针 j=2
  • 当第3个元素匹配失败时,可令主串指针 i 不变,模式串指针 j=1
  • 当第2个元素匹配失败时,可令主串指针 i 不变,模式串指针 j=1
  • 当第1个元素匹配失败时,匹配下一个相邻子串,令 j=0, i++, j++

next数组只和短短的模式串有关,和长长的主串无关

 

5.2KMP算法的优点

  • 之所以只和模式串有关,是因为如果在哪里匹配失败,同时说明在这之前的部分主串和模式串是相同的

  • KMP算法,最坏时间复杂度 O(m+n),其中,求 next 数组时间复杂度 O(m),模式匹配过程最坏时间复杂度 O(n)

  • KMP算法精髓:利用好已经匹配过的模式串的信息

 5.3KMP算法代码实现:

int Index_KMP(SString S, SString T, int next[]){int i=1;     //主串int j=1;     //模式串while(i<S.length && j<=T.length){if(j==0 || S.ch[i]==T.ch[j]){      //第一个元素匹配失败时++j;++i;         //继续比较后继字符}elsej=next[j]   //模式串向右移动}if(j>T.length)return i-T.length; //匹配成功
}

5.4KMP算法之求next数组

5.4.1求next数组代码实现 [含图解]

如上图next数组的求法:对于任何模式串,当第1个字符不匹配时,只能匹配下一个子串,因此,next[1] = 0——表示模式串应右移一位,主串当前指针后移一位,再和模式串的第一字符进行比较;int Index_KMP(SString S, SString T, int next[]){int i=1;     //主串int j=1;     //模式串while(i<S.length && j<=T.length){if(j==0 || S.ch[i]==T.ch[j]){      //第一个元素匹配失败时++j;++i;         //继续比较后继字符}elsej=next[j]   //模式串向右移动}if(j>T.length)return i-T.length; //匹配成功
}

5.4.1next数组的作用:

  • 当模式串的第 j 个字符失配时,从模式串的第 next[j] 的继续往后匹配

5.5KMP算法之求nextval数组

定义:

  • nextval数组是对next数组的优化,用nextval替代next数组,减少了无意义的对比

 nextval数组的求法:

  • 先根据上面的方法算出next数组

  • 先令nextval[1]=0

  • 再根据下面代码算出后面的nextval数组

求nextval数组代码实现[此处本人理解可能有点小问题,但是问题不大;理论任然成立]

for(int j = 2; j <= T.length; j++)
{//让第next值个元素的值和当前元素比较if(T.ch[next[j]] == T.ch[j]){//若相等则让第next值个元素的nextval值复制给当前元素的nextval值nextval[j] = nextval[next[j]];}else{//若不等则让当前元素的next值赋值给当前元素的nextval值nextval[j] = next[j];}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/443985.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

智能边缘计算 | 项目快速部署指南

在数字化浪潮的推动下&#xff0c;边缘计算与人工智能的深度融合正在成为推动智能社会发展的新动力。 边缘计算通过将数据处理和分析任务从中心服务器转移到更接近数据源的端侧&#xff0c;从而显著降低数据传输延迟&#xff0c;提高了响应速度和安全隐私性。在人工智能的加持…

python的特殊方法——魔术方法

前言 __init__(self[]) ​编辑 __call__(self [, ...]) __getitem__(self, key) __len__(self) __repr__(self) / __str__(self) __add__(self, other) __radd__(self, other) 参考文献 前言 官方定义好的&#xff0c;以两个下划线开头且以两个下划线结尾来命名的方法…

在QT中将Widget提升为自定义的Widget后,无法设置Widget的背景颜色问题解决方法

一、问题 在Qt中将QWidget组件提升为自定义的QWidget后&#xff0c;Widget设置的样式失效&#xff0c;例如设置背景颜色为白色失效。 二、解决方法 将已经提升的QWidget实例对象&#xff0c;脱离父窗体的样式&#xff0c;然后再重新设置自己的样式。

[ComfyUI]太赞了!阿里妈妈发布升级版 Flux 图像修复模型,更强细节生成,更高融合度以及更大分辨率支持

小伙伴们还记得我们之前介绍的阿里妈妈发布的 Flux 的 ControlNet 图像修复模型不&#xff0c;之前发布的是 Alpha 早期测试版本&#xff0c;说实话和 Flux 原生的重绘其实差距不大&#xff0c;有些方面甚至还是原生的效果更好。 但是现在&#xff0c;Alpha 的升级版本 Beta 版…

Stable Diffusion绘画 | 签名、字体、Logo设计

第1步&#xff0c;使用 PS&#xff08;小白推荐使用 可画&#xff09;准备一个 512*768 的签名、字体、Logo图片&#xff1a; 第2步&#xff0c;来到模型网站&#xff0c;搜索&#x1f50d;关键词“电商”&#xff0c;找到一款喜欢的 LoRA&#xff1a; 第3步&#xff0c;选择一…

4.STM32-中断

STM32-中断 需求&#xff1a;红灯每两秒进行闪烁&#xff0c;按键key1控制绿灯亮灭 简单的程序代码无法满足要求 如何让STM32既能执行HAL_DELAY这种耗时的任务&#xff0c;同时又能快速响应按键按下这种突发情况呢 设置中断步骤 1.接入中断 将KEY1输入模式由原先的GPIO_In…

布隆过滤器基本原理与使用

目录 1.引言 2.基本定义 3.基本原理 4.实现方法 5.布隆过滤器的优缺点 6.哈希冲突和误判问题 7.大规模数据集Redis中布隆过滤器的性能优化 8.应用场景举例 1.引言 在互联网应用中&#xff0c;随着用户基数和交互数据的爆炸性增长&#xff0c;如何高效地处理点赞、签到、…

vue出现Component name “Politic“ should always be multi-word错误

效果 原因 组件名不能为单个单词&#xff0c;怕和html标签混淆 解决方法 1.选择多个单词区分 2.修改package.json里的rules规则&#xff0c;忽略文件命名校验

跨平台游戏的特点

跨平台游戏已成为视频游戏行业的主要趋势&#xff0c;这是由于对各种设备和操作系统之间无缝游戏的需求日益增长。这种方法允许玩家在多个平台&#xff08;如游戏机、PC和移动设备&#xff09;上享受他们最喜欢的游戏&#xff0c;同时保持相同的体验和进度。随着越来越多的开发…

【2024年最新】基于springboot+mysql就业信息管理系统

技术摘要 技术框架&#xff1a;以springboot作为框架&#xff0c;业务模式&#xff1a;B/S模式数据库&#xff1a;MySql作为后台运行的数据库服务器&#xff1a;使用Tomcat用为系统的服务器 系统展示 系统实现功能 本次实现一个就业信息管理系统&#xff0c;通过这个系统能够满…

【北京迅为】《STM32MP157开发板嵌入式开发指南》-第二十二章 安装VMware Tool 工具

iTOP-STM32MP157开发板采用ST推出的双核cortex-A7单核cortex-M4异构处理器&#xff0c;既可用Linux、又可以用于STM32单片机开发。开发板采用核心板底板结构&#xff0c;主频650M、1G内存、8G存储&#xff0c;核心板采用工业级板对板连接器&#xff0c;高可靠&#xff0c;牢固耐…

ssrf学习(ctfhub靶场)

ssrf练习 目录 ssrf漏洞 漏洞形成原理&#xff08;来自网络&#xff09; 寻找ssrf漏洞&#xff0c; 靶场题目 第一题&#xff08;url探测网站下文件&#xff09; 第二关&#xff08;使用伪协议&#xff09; 关于http和file协议的理解 file协议 http协议 第三关&…

猫头虎分享已解决Bug || Error: ERESOLVE unable to resolve dependency tree 解决方案

&#x1f42f; 猫头虎分享已解决Bug || Error: ERESOLVE unable to resolve dependency tree 解决方案 摘要 在前端开发中&#xff0c;尤其是使用 Node.js 和 npm 管理依赖时&#xff0c;ERESOLVE unable to resolve dependency tree 错误是很多开发者遇到的常见问题。这个 Bu…

jQuery 用户登录页面非空校验与登录测试

文章目录 实战介绍准备工作创建网页导入样式表和jQuery库编写页面代码编写脚本代码创建成功页面浏览网页和测试结束语 实战介绍 大家好&#xff0c;今天我们将一起学习如何使用jQuery来为用户登录页面进行非空校验和登录测试。通过这个实战项目&#xff0c;你将学会如何通过jQ…

新版 Notepad++ 下载与安装教程

一、软件准备&#xff1a;麻烦点我 二、双击下载好的 notepad 软件进行安装&#xff0c;选择 “简体中文”。 三、默认 “下一步” 安装。 四、单击 “我接受” 按钮。 五、自定义安装位置&#xff0c;个人建议安装在 D 盘。 六、选择组件&#xff0c;默认 “下一步”。 七、勾…

使用Diskgenius系统迁移

使用Diskgenius系统迁移 1、使用系统迁移2、注意点3、新备份的系统盘装在电脑上可能出现盘符错乱导致开机不进入桌面情况 1、使用系统迁移 参考视频&#xff1a; DiskGenius无损系统迁移&#xff0c;换硬盘无需重装系统和软件 2、注意点 1&#xff09;新的硬盘里面的所有资料…

第十八篇:一文说清楚ICMP的底层原理

作为程序员或者网络工程师&#xff0c;有时候无法访问对方主机&#xff1b;导致这个现象的有很多原因&#xff0c;那要排查具体的网络原因&#xff0c;可能会用到ping的指令。而ping的底层实现是互联⽹控制报⽂协议&#xff08;ICMP&#xff09;。 ICMP 全称是 Internet Contr…

前端_002_CSS扫盲

文章目录 概念选择器常用属性背景边框高度和宽度颜色文本字体链接表格里对齐显示相关溢出&#xff0c;滚动条属性 伪类和伪元素 概念 1.书写格式&#xff1a; 选择器{ 属性名:属性值 ; 属性名:属性值 ; } 2.文件后缀.css 选择器 元素选择器 [tag] id选择器 #[id_name] c…

直线导轨在自动化设备中需要注意什么?

直线导轨属于精密传动配件&#xff0c;因而在使用时要求有相当地慎重态度&#xff0c;如果使用不当&#xff0c;也不能达到预期的性能效果&#xff0c;尤其是保管和保养不当&#xff0c;很容易造成导轨失效等问题&#xff0c;导致无法正常使用。因此&#xff0c;自动化设备中使…

string 类

一、为什么学习 string 类 1、C语言中的字符串 C语言中&#xff0c;字符串是以\0结尾的一些字符的集合&#xff0c;为了操作方便&#xff0c;C标准库中提供了一些str系列 的库函数&#xff0c;但是这些库函数与字符串是分离开的&#xff0c;不太符合OOP的思想&#xff0c;而且底…