算法性能测试c语言,(最新整理)各种查找算法的性能比较测试(顺序查找、二分查找)...

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

1、完整)各种查找算法的性能比较测试(顺序查找、二分查找)(完整)各种查找算法的性能比较测试(顺序查找、二分查找)编辑整理:尊敬的读者朋友们:这里是精品文档编辑中心,本文档内容是由我和我的同事精心编辑整理后发布的,发布之前我们对文中内容进行仔细校对,但是难免会有疏漏的地方,但是任然希望((完整)各种查找算法的性能比较测试(顺序查找、二分查找))的内容能够给您的工作和学习带来便利。同时也真诚的希望收到您的建议和反馈,这将是我们进步的源泉,前进的动力。本文可编辑可修改,如果觉得对您有帮助请收藏以便随时查阅,最后祝您生活愉快 业绩进步,以下为(完整)各种查找算法的性能比较测试(顺序查找、二分查找)的全部。

2、内容。算法设计与分析各种查找算法的性能测试目录摘要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 。

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

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

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

6、是要查找的元素 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;/选择查找的最大的范围 M。

7、id=(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 二分查找(非递归)法的伪代码算法:二分查找(非递归)法目的:在给定的集合(或者是多重集,允许多个元素具有相同的值)中找寻一个给定的值。前提:给定一给定一个集合(或多重集)(A1、。

8、A2、A3、A4。.。An).返回:寻找出给定值.伪代码如下:int BinarySearch(int a,int n,int k) /查找表放在数组a中,n是查找表中元素的个数,k是待查找的元素。 Low=0; high=n-1; /置区间初值while(low0 & ai!=key)/*当i大于0并且目前找到的元素和要找的元素不相等,则执行下一条语句/i-;return i;/i的值为0则没找到,为非0则i为要查找元素的位置/二分查找的递归/int diguisearch(int a,int n,int key)/数组a1 an存放查找集合,n是数组中元素的个数(即查找表的长度),key是。

9、要查找的元素int High,Low,Mid;/定义了整形变量High,Low,MidLow=0,High=n-1;/选择查找的最大的范围 Mid=(Low+High)/2; if ((Low=High)|(n=-1) return -1;/数字1表示没有结果else if (aMid=key) return Mid; /找到要查找的元素 else if (aMidkey) return (diguisearch(a,Mid-1,key);/需要在左边的更小的范围内查找 elsereturn (diguisearch(a+Mid+1,n-Mid,key);/在右边的更大的范围内查找 /二分法非。

10、递归int feidiguisearch(int a,int n,int key)/*数组a1 an存放查找集合,n是数组中元素的个数(即查找表的长度),key是要查找的元素*/int mid;/定义了一个整形变量midint low=0;/定义了一个整形变量low,并且赋值为0int high=n1;/选择查找的最大的范围while(lowhigh) mid=(low+high)/2; if (key=amid)/如果数组的中间元素和要查找的元素相等return mid;/查找成功else if (keyamid) low=mid+1;/在后半区间查找 elsehigh=mid1;/在前半区。

11、间查找 return -1;/查找失败void main()int n=200; /定义一个变量n,n=200int a200; /定义一个数组a,数组里数的个数是200int key=59;srand(unsigned)time(NULL)); /初始化随机函数种子,這句是拿系统时间作为种子,由于时间是变化的,种子变化,可以产生不相同的随机数/for(int i=0;in;i+)/初始化变量i的值为0,当i=0时执行循环,在每次循环后i执行加1操作ai=rand()%100; /随机数的取值从0到100之间/for(int b=0;bn;b+)printf(%d ,ab); */clock_。

12、t start,end; /声明时间变量double duration; /声明用于记录时间的变量start=clock();/开始记录时间SeqSearch(a,n,key);/计算直接查找规模为n的时候用的时间printf(”d”,key);/输出要查找的元素,即keyend=clock();/停止记录时间duration=(double)(end-start)/CLOCKS_PER_SEC; /求时间差并把时间差记录在 duration中printf(nthe SeqSearch time is=%f secondsn,duration); /输出时间差,也就是计算所用的时间start=。

13、clock();/开始记录时间diguisearch(a,n,key); /计算二分递归查找规模为n的时候用的时间printf(%d”,key);/输出要查找的元素,即keyend=clock();/停止记录时间duration=(double)(endstart)/CLOCKS_PER_SEC;/求时间差并把时间差记录在duration中printf(”nthe diguisearch time is=%f secondsn,duration); /输出时间差,也就是计算所用的时间start=clock();/开始记录时间feidiguisearch(a,n,key);/计算二分非递归查找规模为n的时候用的时间printf(%d,key);/输出要查找的元素,即keyend=clock();/停止记录时间duration=(double)(endstart)/CLOCKS_PER_SEC;/求时间差并把时间差记录在duration中printf(”nthe feidiguisearch time is=f secondsn”,duration); /输出时间差,也就是计算所用的时间system(”pause”); /j结束程序运行。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值