各种查找算法的性能比较测试(顺序查找、二分查找).doc
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《各种查找算法的性能比较测试(顺序查找、二分查找).doc》由会员分享,可在线阅读,更多相关《各种查找算法的性能比较测试(顺序查找、二分查找).doc(17页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、算法设计与分析各种查找算法的性能测试目录摘要4第一章:简介(Introduction)51.1 算法背景5第二章:算法定义(Algorithm Specification)52.1 数据结构52.2顺序查找法的伪代码62.3 二分查找(递归)法的伪代码62.4 二分查找(非递归)法的伪代码7第三章:测试结果(Testing Results)93.1 测试案例表93.2 散点图10第四章:分析和讨论124.1 顺序查找124.1.1 基本原理124.2.2 时间复杂度分析124.2.3优缺点124.2.4该进的方法134.2 二分查找(递归与非递归)134.2.1 基本原理134.2.2 时间复
2、杂度分析144.2.3优缺点144.2.4 改进的方法14附录:源代码(基于C语言的)16声明18摘要在计算机许多应用领域中,查找操作都是十分重要的研究技术。查找效率的好坏直接影响应用软件的性能,而查找算法又分静态查找和动态查找。我们设置待查找表的元素为整数,用不同的测试数据做测试比较,长度取固定的三种,对象由随机数生成,无需人工干预来选择或者输入数据。比较的指标为关键字的查找次数。经过比较可以看到,当规模不断增加时,各种算法之间的差别是很大的。这三种查找方法中,顺序查找是一次从序列开始从头到尾逐个检查,是最简单的查找方法,但比较次数最多,虽说二分查找的效率比顺序查找高,但二分查找只适用于有序
3、表,且限于顺序存储结构。关键字:顺序查找、二分查找(递归与非递归)第一章:简介(Introduction) 1.1 算法背景 查找问题就是在给定的集合(或者是多重集,它允许多个元素具有相同的值)中找寻一个给定的值,我们称之为查找键。 对于查找问题来说,没有一种算法在任何情况下是都是最优的。有些算法速度比其他算法快,但是需要较多的存储空间;有些算法速度非常快,但仅适用于有序数组。查找问题没有稳定性的问题,但会发生其他的问题(动态查找表)。 在数据结构课程中,我们已经学过了几种查找算法,比较有代表性的有顺序查找(蛮力查找),二分查找 (采用分治技术),哈希查找(理论上来讲是最好的查找方法)。 第二
4、章:算法定义(Algorithm Specification)2.1 数据结构三种查找都是以整形数组作为主要的数据结构,如Int an。我们主要测试的是算法的性能,并不是仅仅对算法的查找,以数组作为主要的数据结构能满足实验的要求。2.2顺序查找法的伪代码 算法:顺序查找法目的:在给定的集合(或者是多重集,允许多个元素具有相同的值)中找寻一个给定的值。前提:给定一给定一个集合(或多重集)(A1、A2、A3、A4.An)。返回:寻找出给定值。伪代码如下: int SeqSearch1(int r , int n, int k) /数组r1 rn存放查找集合,n是数组中元素的个数(即查找表的长度),
5、k是要查找的元素 i=n;/从后往前把表中的元素与要查找的元素进行比较 while (i0 & ri!=k) i-; return i;/i的值为0则没找到,为非0则i为要查找元素的位置 2.3 二分查找(递归)法的伪代码 算法:二分查找(递归)法 目的:在给定的集合(或者是多重集,允许多个元素具有相同的值)中找寻一个给定的值。 前提:给定一给定一个集合(或多重集)(A1、A2、A3、A4.An)。 返回:寻找出给定值。 伪代码如下:int search(int a,int n,int k)/查找表放在数组a中,n是查找表中元素的个数,k是待查找的元素 Low=0,High=n-1;/选择查找
6、的最大的范围 Mid=(Low+High)/2; if (Low=High)|(n=-1) return -1;/数字-1表示没有结果else if (aMid=k) return Mid; /找到要查找的元素 else if (aMidg) return (search(a,Mid-1,g);/需要在左边的更小的范围内查找 elsereturn (search(a+Mid+1,n-Mid,g);/在右边的更大的范围内查找 2.4 二分查找(非递归)法的伪代码 算法:二分查找(非递归)法目的:在给定的集合(或者是多重集,允许多个元素具有相同的值)中找寻一个给定的值。前提:给定一给定一个集合(或
7、多重集)(A1、A2、A3、A4.An)。返回:寻找出给定值。伪代码如下:int BinarySearch(int a,int n,int k) /查找表放在数组a中,n是查找表中元素的个数,k是待查找的元素。 Low=0; high=n-1; /置区间初值while(lowai) low=middle+1;/在后半区间查找 elsehigh=middle-1;/在前半区间查找 return 0;/查找失败第三章:测试结果(Testing Results)3.1 测试案例表实验项目二 各种查找算法的性能测试(数据数多少不同时用时)数据N排序3080200200010000顺序查找0000.00
8、150.002二分查找(递归)00000.001二分查找(非递归)00000实验项目二 各种查找算法的性能测试(查找值不同时用时)数据K排序10251204775000顺序查找00000二分查找(递归)00000二分查找(非递归)000003.2 散点图 在测试过程中n的值取了30、80、200、2000、10000;取这些值是因为我想测试在随机数多少不一的情况下所用时间的区别。经过实验发现查找过程中三种查找方法都很迅速,但当数字增大时还是有些差别,顺序查找用时最多。 在实验过程中我们在同规模5000的情况下把key值取了10、25、120、477、5000;取這些值是想看看在查找值不一的情况
9、下所用时间的不同。经过实验发现无论key取值多少三种查找时间依旧相同。 实验中我们所预期的结果是:输入不同的规模,根据随机数的产生,三种查找方法都会出现相应的时间。可是,实验过程中,随机数的原因,很多次测量都是0,就只有极少数的情况下会出现时间,而且出现的时间都很小,都是0.001或者0.002。第四章:分析和讨论4.1 顺序查找4.1.1 基本原理 从表的一端向另一端逐个进行记录的关键字和给定值(要查找的元素)的比较,若某个记录的关键字和给定值比较相等,则查找成功,找到所查找记录;反之,若直至第一个记录,其关键字和给定值比较都不等,则表明表中没有所查记录,查找不成功。4.2.2 时间复杂度分
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 各种 查找 算法 性能 比较 测试 顺序 二分
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内