【算法设计与分析】实验1:字符串匹配问题的算法设计与求解

目录

一、实验目的

二、实验环境

三、实验内容 

四、核心代码

五、记录与处理

六、思考与总结

七、完整报告和成果文件提取链接


一、实验目的

        给定一个文本,在该文本中查找并定位任意给定字符串。

        1、深刻理解并掌握蛮力法设计思想

        2、提高应用蛮力法设计算法的技能;

        3、理解观点:用蛮力法设计算法策略,一般来说,经过适度的努力后,都可以对算法的第一个版本进行一定程度的改良,改进其时间性能。

二、实验环境

        1、机房电脑  Window7

        2、Eclipse/DEVC++等

三、实验内容 

1、针对给定两组字符串,分别利用BF算法及KMP算法开展问题分析、建模、算法设计与优化;

(1)问题分析:

当给出两组字符串,主串s,子串t,要想找到子串t在主串s中的位置,常规时我们用肉眼可以一眼看出,但当字符串非常多时,问题就变得复杂了,用代码思想解决问题时,我们最容易想到暴力匹配BF算法

为了避免BF算法多次回溯的缺点,我们要尽量减少回溯的次数。

KMP算法则提出了采用相等前后缀来解决BF算法多次回溯的缺点。比如:

根据KMP算法的思想,两个字符串拥有相同部分的前后缀,所以只用移动一部分就可以了

求出其最长相等前后缀是关键,根据此数组存储数值——表示该处字符不匹配时应该回溯到的字符下标

求出子串的next数组

在下面情况时,a与c不匹配:

将子串的指针移动到下标为2的字符下。

假设主串长度为m,子串长度为n ,KMP算法的时间复杂度为O(m+n),BF算法的空间复杂度为O(n),与BF算法相比,算法效率提高了很多。

(2)算法改进

而对于KMP算法,还有需要改进的地方,根据nextval的值,我们很容易就知道回溯后的字符与原字符是否相同,这样就减少了原KMP算法中,部分重复回溯的过程。

对上述算法进行时间复杂性分析,并输出程序运行时间及运行结果。

最好情况下,时间复杂度为O(n);全部遍历完时的最差时间复杂度为O(m*n),算法空间复杂度为O(1),BF算法耗时间不耗费空间。KMP算法的时间复杂度为O(m+n),空间复杂度为O(n),与BF算法相比,算法效率提高了很多。

四、核心代码

int BF(SqString s,SqString t)            //BF算法 
{
	int i=0,j=0;
	while(i<s.length&&j<t.length)		
	{
		if(s.data[i]==t.data[j])		
		{
			i++;						
			j++;
		}
		else
		{
			i=i-j+1;					
			j=0;						
		}
	}
	if(j>=t.length) 					
	    return(i-t.length);		
	else
	    return(-1);
}

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])		
		{
			j++;k++;
			next[j]=k;						
		}
		else k=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++;
		}
		else j=next[j];
	}
	if(j>=t.length)
	    return(i-t.length);
	else
	    return(-1);
}

void GetNextval(SqString t,int nextval[])  //求模式串t的nextval数组,进行KMP的代码优化
{
	int j=0,k=-1;							
	nextval[0]=-1;							
	while(j<t.length-1)
	{
		if(k==-1||t.data[j]==t.data[k])		
		{									
			j++;k++;						
			if(t.data[j]!=t.data[k])		
			   nextval[j]=k;
			else
			   nextval[j]=nextval[k];		
		}
		else k=nextval[k];
	}
}

五、记录与处理

实验数据及结果分析。实验时输入多组测试数据,以及对应的算法运行结果截图、算法运行时间

六、思考与总结

对于字符串匹配问题两种算法以及改进的对比:

1.BF算法,暴力匹配法,即逐个字符进行比对,遍历主串,从每个字符开始与子串进行比较。若字符不匹配,主串回溯到下一个字符,子串回到起始位置。时间复杂度:最好情况为O(n),最坏情况为O(m*n);空间复杂度为O(1)。

缺点:效率极低。

2.KMP算法利用了相等前后缀避免多次回溯,使用next数组记录子串的最长相等前后缀,计算子串的next数组,遍历主串和子串,不匹配时,子串根据next数组进行回溯。时间复杂度为O(m+n),空间复杂度为O(n)。

缺点:在某些情况下,如重复字符较多,会有冗余回溯。

七、完整报告和成果文件提取链接

完整可运行代码以及相关实验报告以下链接可获取:
链接: https://pan.baidu.com/s/1iss6-C2nxZQGkEpo-WDn0A?pwd=g5cg 提取码: g5cg 
 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

10.6.1 文本文件读、写和追加

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 文本文件的读写通常的做法是建立一个与文件关联的filestream&#xff0c;然后使用StreamReader读取或者StreamWriter写入。 为了详…

DevEco Studio 4.1中如何创建OpenHarmony的Native C++ (NAPI)程序

目录 引言 操作步骤 结语 引言 OpenHarmony的开发工具变化很快&#xff0c;有的时候你安装以前的教程进行操作时会发现界面和操作方式都变了&#xff0c;进行不下去了。比如要在OpenHarmony中通过NAPI调用C程序&#xff0c;很多博文&#xff08;如NAPI篇【1】——如何创建含…

达梦拷贝DM_HOME的复制安装

近期一个项目需求&#xff0c;需要在没有安装包的情况下&#xff0c;将达梦数据库安装到虚机上&#xff08;生产机上安装了达梦&#xff09;&#xff0c;故采用直接打包生产机DM_HOME的方式拷贝至虚机&#xff0c;再依次执行达梦的部分指令完成安装。以下为验证的步骤&#xff…

【MySQL】初始MySQL、库与表的操作

目录 基本使用 使用案例 SQL分类 存储引擎 库的操作 字符集和校验规则 查看系统默认字符集和校验规则 查看数据库支持的字符集 查看数据库支持的字符集校验规则 指定编码常见数据库 校验规则对数据库的影响 操纵数据库 库的备份与恢复 表的操作 创建表 查看表 …

AI大模型开发原理篇-2:语言模型雏形之词袋模型

基本概念 词袋模型&#xff08;Bag of Words&#xff0c;简称 BOW&#xff09;是自然语言处理和信息检索等领域中一种简单而常用的文本表示方法&#xff0c;它将文本看作是一组单词的集合&#xff0c;并忽略文本中的语法、词序等信息&#xff0c;仅关注每个词的出现频率。 文本…

“爱”之浅谈(一)

《九重紫》里 陈嘉有了爱情 从粗糙的一介武夫和赌徒&#xff0c;变得温柔细致 万皇后伤于爱情 从温柔的眼里有爱有光的小姑娘&#xff0c;变成狠毒的残害忠良的、意图谋反的、卷动举国风云的操盘手 “爱让怯懦者勇敢&#xff0c;让高傲者低头” “爱是软肋&#xff0c;也是…

图漾相机搭配VisionPro使用简易教程

文章目录 1.下载并安装VisionPro软件2.下载PercipioCameraForVisionPro软件包3.软件部署4.测试流程4.1 遍历VisionPro SDK支持的参数4.2 设置示例4.2.1_cameraSingle.SetTriggerMode4.2.2 _cameraSingle.SetRegistration4.2.3_cameraSingle.SetInt4.2.4 _cameraSingle.GetInt4.…

Versal - 基础3(AXI NoC 专题+仿真+QoS)

目录 1. 简介 2. 示例 2.1 示例说明 2.2 创建项目 2.2.1 平台信息 2.2.2 AXI NoC Automation 2.2.3 创建时钟和复位 2.3 配置 NoC 2.4 配置 AXI Traffic 2.5 配置 Memory Size 2.6 Validate BD 2.7 添加观察信号 2.8 运行仿真 2.9 查看结果 2.9.1 整体波形 2.9…

iperf 测 TCP 和 UDP 网络吞吐量

注&#xff1a;本文为 “iperf 测网络吞吐量” 相关文章合辑。 未整理去重。 使用 iperf3 监测网络吞吐量 Tom 王 2019-12-21 22:23:52 一 iperf3 介绍 (1.1) iperf3 是一个网络带宽测试工具&#xff0c;iperf3 可以擦拭 TCP 和 UDP 带宽质量。iperf3 可以测量最大 TCP 带宽…

ResNeSt: Split-Attention Networks论文学习笔记

这张图展示了一个名为“Split-Attention”的神经网络结构&#xff0c;该结构在一个基数组&#xff08;cardinal group&#xff09;内进行操作。基数组通常指的是在神经网络中处理的一组特征或通道。图中展示了如何通过一系列操作来实现对输入特征的注意力机制。 以下是图中各部…

自动驾驶---苏箐对智驾产品的思考

1 前言 对于更高级别的自动驾驶&#xff0c;很多人都有不同的思考&#xff0c;方案也好&#xff0c;产品也罢。最近在圈内一位知名的自动驾驶专家苏箐发表了他自己对于自动驾驶未来的思考。 苏箐是地平线的副总裁兼首席架构师&#xff0c;同时也是高阶智能驾驶解决方案SuperDri…

【C++】内联函数inline、关键字auto与新式for

内联函数 内联函数背景 我们在使用C语言中我们都学过函数&#xff0c;我们知道函数在调用的过程中需要开辟栈帧。如果我们需要频繁的调用一个函数&#xff0c;假设我们调用10次Add()函数&#xff0c;那我们就需要建立10次栈帧。我们都知道在栈帧中要做很多事情&#xff0c;例如…

Day24-【13003】短文,数据结构与算法开篇,什么是数据元素?数据结构有哪些类型?什么是抽象类型?

文章目录 13003数据结构与算法全书框架考试题型的分值分布如何&#xff1f; 本次内容概述绪论第一节概览什么是数据、数据元素&#xff0c;数据项&#xff0c;数据项的值&#xff1f;什么是数据结构&#xff1f;分哪两种集合形式&#xff08;逻辑和存储&#xff09;&#xff1f…

论文阅读(十六):利用线性链条件随机场模型检测阵列比较基因组杂交数据的拷贝数变异

1.论文链接&#xff1a;Detection of Copy Number Variations from Array Comparative Genomic Hybridization Data Using Linear-chain Conditional Random Field Models 摘要&#xff1a; 拷贝数变异&#xff08;CNV&#xff09;约占人类基因组的12%。除了CNVs在癌症发展中的…

深入理解若依RuoYi-Vue数据字典设计与实现

深入理解若依数据字典设计与实现 一、Vue2版本主要文件目录 组件目录src/components&#xff1a;数据字典组件、字典标签组件 工具目录src/utils&#xff1a;字典工具类 store目录src/store&#xff1a;字典数据 main.js&#xff1a;字典数据初始化 页面使用字典例子&#xf…

思维练习题

目录 第一章 假设法1.题目1. 如何问问题2. 他们的职业是分别什么3. 谁做对了4. 鞋子的颜色 2.答案 空闲时间写一些思维题来锻炼下思维逻辑&#xff08;题目均收集自网上&#xff0c;分析推理为自己所写&#xff09;。 第一章 假设法 一个真实的假设往往可以让事实呈现眼前&…

亲测有效!解决PyCharm下PyEMD安装报错 ModuleNotFoundError: No module named ‘PyEMD‘

解决PyCharm下PyEMD安装报错 PyEMD安装报错解决方案 PyEMD安装报错 PyCharm下通过右键自动安装PyEMD后运行报错ModuleNotFoundError: No module named ‘PyEMD’ 解决方案 通过PyCharm IDE python package搜索EMD-signal&#xff0c;选择版本后点击“install”执行安装

DVC - 数据版本和机器学习实验的命令行工具和 VS Code 扩展

文章目录 一、关于 DVC二、快速启动三、DVC的工作原理四、VS代码扩展五、安装Snapcraft&#xff08;Linux&#xff09;Chocolatey (Windows)Brew (mac OS)Anaconda (Any platform)PyPI&#xff08;Python&#xff09;Package (Platform-specific)Ubuntu / Debian (deb)Fedora /…

实现前端当中的页面过渡动画

使用 HTML、CSS 和 JavaScript 实现页面过渡动画 在现代网页设计中&#xff0c;用户体验是至关重要的。而页面切换时的平滑过渡效果&#xff0c;不仅能让界面更加美观&#xff0c;也能增强用户的互动体验。 引言 作为一名热爱前端开发的程序员&#xff0c;我一直在寻找能提…

AJAX笔记入门篇

黑马程序员视频地址&#xff1a; 黑马程序员前端AJAX入门到实战全套教程https://www.bilibili.com/video/BV1MN411y7pw?vd_source0a2d366696f87e241adc64419bf12cab&spm_id_from333.788.videopod.episodes&p2https://www.bilibili.com/video/BV1MN411y7pw?vd_source…