各种查找算法的性能比较测试(顺序查找、二分查找)

上传人:hs****ma 文档编号:507431552 上传时间:2023-03-07 格式:DOCX 页数:18 大小:70.59KB
返回 下载 相关 举报
各种查找算法的性能比较测试(顺序查找、二分查找)_第1页
第1页 / 共18页
各种查找算法的性能比较测试(顺序查找、二分查找)_第2页
第2页 / 共18页
各种查找算法的性能比较测试(顺序查找、二分查找)_第3页
第3页 / 共18页
各种查找算法的性能比较测试(顺序查找、二分查找)_第4页
第4页 / 共18页
各种查找算法的性能比较测试(顺序查找、二分查找)_第5页
第5页 / 共18页
点击查看更多>>
资源描述

《各种查找算法的性能比较测试(顺序查找、二分查找)》由会员分享,可在线阅读,更多相关《各种查找算法的性能比较测试(顺序查找、二分查找)(18页珍藏版)》请在金锄头文库上搜索。

1、算法设计与分析各种查找算法的性能测试目录摘要3第一章: 简介 (Iiitioduction) 41.1算法背景4第二章: 算法定义 (AlgoritlmiSpecification) 42.1数据结构42.2顺序查找法的伪代码52.3二分查找(递归)法的伪代码52.4二分查找(非递归)法的伪代码6第三章: 测 试结果 (Testing Results) 83.1测试案例表83.2散点图9第四章:分析和讨论114.1顺序查找114.1.1基本原理114.2.2时间复杂度分析114.2.3优缺点114.2.4该进的方法124.2二分查找(递归与非递归)124.2.1基本原理124.2.2时间复杂度

2、分析134.2.3优缺点134.2.4改进的方法13附录:源代码(基于C语言的)15声明错误!未定义书签。摘要在计算机许多应用领域中,查找操作都是十分重要的研究技术。 查找效率的好坏直接影响应用软件的性能,而查找算法又分静态查找 和动态查找。我们设置待查找表的元素为整数,用不同的测试数据做测试比 较,长度取固定的三种,对象由随机数生成,无需人工干预来选择或 者输入数据。比较的指标为关键字的查找次数。经过比较可以看到, 当规模不断增加时,各种算法之间的差别是很大的。这三种查找方法 中,顺序查找是一次从序列开始从头到尾逐个检查,是最简单的查找 方法,但比较次数最多,虽说二分查找的效率比顺序查找高,

3、但二分 查找只适用于有序表,且限于顺序存储结构。关键字:顺序查找、二分查找(递归与非递归)第一章:简介(Introduction)1-1算法背景查找问题就是在给定的集合(或者是多重集,它允许多个元 素具有相同的值)中找寻一个给定的值,我们称之为查找键。对于查找问题来说,没有一种算法在任何情况下是都是最优 的。有些算法速度比其他算法快,但是需要较多的存储空间;有 些算法速度非常快,但仅适用于有序数组。查找问题没有稳定性 的问题,但会发生其他的问题(动态查找表)。在数据结构课程中,我们已经学过了几种查找算法,比较 有代表性的有顺序查找(蛮力查找),二分查找(采用分治技术), 哈希查找(理论上来讲是

4、最好的查找方法)。第二章:算法定义(Algorithm Specification)2.1数据结构三种查找都是以整形数组作为主要的数据结构,如Int ano我 们主要测试的是算法的性能,并不是仅仅对算法的查找,以数组作为 主要的数据结构能满足实验的要求。2.2顺序查找法的伪代码算法:顺序查找法目的:在给定的集合(或者是多重集,允许多个元素具有相同的 值)中找寻一个给定的值。前提:给定一给定一个集合(或多重集)(A1、A2、A3、A4.An)。返回:寻找出给定值。伪代码如下:int SeqSearchl (int r , int n, int k) 数组 rl、r n 存放查找集合,n是数组中元

5、素的个数(即查找表的长度),k是要查 找的元素i=n;/从后往前把表中的元素与要查找的元素进行比较whi.le (i0 & ri !=k)-;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, H

6、igh=n-1;/选择查找的最大的范围Mid二(Low+High)/2;if (Low二High) | | (n=-l) return T;/数字T 表示没有结果else if (aMid=k) return Mid; /找到要查找的元素else if (aMidg)return (search(a, Midl, g) ;/需要在左边的更小的范围内查 找elsereturn (search(a+Mid+1, nMid, g) ;/在右边的更大的范围内 查找2.4二分査找(非递归)法的伪代码算法:二分查找(非递归)法目的:在给定的集合(或者是多重集,允许多个元素具有相同的值)中找寻一个给定的值。

7、前提:给定一给定一个集合(或多重集)(A1、A2、A3、A4.An)。返回:寻找出给定值。伪代码如下:int BinarSearch(int a, int n, int k) /查找表放在数组 a 中,n是查找表中元素的个数,k是待查找的元素。Low二0;high=n-l; /置区间初值while (lowaij)low=middle+l; /在后半区间查找elsehigh二middleT ;/在前半区间查找return 0;/查找失败第三章:测试结果(Testing Results)3.1测试案例表实验项目二 各种查找算法的性能测试(数据数多少不同时用时)数据A308020020001000

8、0顺序查找0000.00150.002二分查找(递归)00000.001二分查找(非递归)00000实验项目二 各种查找算法的性能测试(查找值不同时用时)数据A10251204775000顺序查找00000二分查找00000(递归)二分查找00000(非递归)3.2散点图各种查找的性能比巨规模+ 顺序查找 亠二分递归二分非递归在测试过程中n的值取了 30、80、200、2000、10000;取这些 值是因为我想测试在随机数多少不一的情况下所用时间的区别。经过 实验发现查找过程中三种查找方法都很迅速,但当数字增大时还是有 些差别,顺序查找用时最多。性能比较+顺序查找 亠二分查找(递归)二分查找(

9、非递归)在实验过程中我们在同规模5000的情况下把key值取了 10、25、 120、477、5000;取這些值是想看看在查找值不一的情况下所用时间 的不同。经过实验发现无论key取值多少三种查找时间依旧相同。实验中我们所预期的结果是:输入不同的规模,根据随机数的产 生,三种查找方法都会出现相应的时间。可是,实验过程中,随机数 的原因,很多次测量都是0,就只有极少数的情况下会出现时间,而 且出现的时间都很小,都是0. 001或者0. 002o第四章:分析和讨论4.1顺序査找4.1.1基本原理从表的一端向另一端逐个进行记录的关键字和给定值(要查找 的元素)的比较,若某个记录的关键字和给定值比较相

10、等,则查找成 功,找到所查找记录;反之,若直至第一个记录,其关键字和给定值 比较都不等,则表明表中没有所查记录,查找不成功。4.2.2时间复杂度分析由于顺序查找是从表的一端向另一端逐个进行记录的关键字和 给定值的比较,对于n个元素的表,不成功的比较次数为n,查找成 功:最好的情况为1次,最差的情况为n次,所以查找成功时的平均 查找长度为(n+l)/2,且顺序查找的时间复杂度为O(n)。4.2.3优缺点与其他查找算法相比,其缺点是平均查找长度较大,特别是当 n较大时,查找效率低,但他有个很大的优点是算法简单且适应面广,它对表的结构无任何要求,无论记录是否按关键字有序均可应用。424该进的方法/轴

11、入n自然语言描述:当没有超出范围并且没有找到 就要继续查找.设置变量r*-0, result没找到N/ 咖II I /I = 10Yd 11 nN枚举算法的一个案例可以用“找钥匙”问題为模型 循环结构嵌套分支结构/ 抽入nN=10 andd 11 = n1 f F4-0/ttUl r/工()4.2二分査找(递归与非递归)4.2.1基本原理二分查找又称折半查找,二分查找首先要求待查找的表是有序表, 如果要查找的元素是表的中间的那个元素,则找到要查找的元素,查 找成功;如果要查找的元素比中间的那个元素小则使用相同的策略只 在左边的区间查找就可以;如果要查找的元素比中间的那个元素大, 则使用相同的策

12、略在右边的区间进行查找;每次将待查找的元素的所 在区间缩小一半。4.2.2时间复杂度分析二分查找的时间复杂度是0(log(n),最好的情况是指针mid指的 第一个数就是要找的值,最坏的情况的所找的值是第一个或最后一个 数,最坏情况下的时间复杂度是0(n)。4.2.3优缺点查找的效率较高,但是只适用于有序表,且限于顺序存储结构,对 线性链表无法有效的进行查找,还有二分查找在一些特殊情况下,其 查找效率很低,如查找元素是数列中的第一个元素和最后一个元素。4.2.4改进的方法改进后的二分查找算法思路:若k不等于amid,则同时改变 low和high的值,使下一次的啊low与k之间的距离尽可能等于k

13、与ahigh之间的距离,为下一次的二分查找k成功提供最大的可能。 伪代码如下:(1) low=0; high=n-l(2) Index=l(3) Mid=(high+low)/2(4 ) While (low=high and index1)(5) If kainid(9) Low=mid+1(10) High=low+2*pos2(11) Else index=mid(12) Return index注:任意两个元素ai与aj之间的距离为pos, posl为k与a high之 间的距离,pos2为k与alow之间的距离。附录:源代码(基于C语言的)#include stdio.h”#incl

14、ude “stdlib.h#include time.h/*顺序查找*/int SeqSearch(int a , int n, int key) 数组 al an存放查找集合,n 是数组中 元素的个数(即查找表的长度),key是要查找的元素int i;定义了一个整形变量ii二n;从后往前把表中的元素与要查找的元素进行比较while (i0 & ai!=key)/*当i大于0并且目前找到的元素和要找的元素不相等, 则执行下一条语句*/i;return i;/i的值为0则没找到,为非0贝9 i为要查找元素的位置/*二分查找的递归*/int diguisearch(int a,int n,int key)/数组 al an存放查找集合,n 是数组中元 素的个数(即查找表的长度),key是要

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 学术论文 > 其它学术论文

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号