二分搜索实验报告

合集下载

非线性方程解法二分法实验报告

非线性方程解法二分法实验报告

第七章非线性方程解法⒈二分法考察有根区间[a, b],取中点x0=(b+a)/2 将它分为两半,假设中点x0不是f(x)的零点,然后进行根的搜索,即查找f(x0)与f(a)是否同号,如果确系同号,说明所求的根x*在x0的右侧,这是令a1= x0,b1=b;否则x*必在x0的左侧,这是令a1=a,b1=x0,不管出现哪一种情况,新的有根区间[a1, b1]的长度仅为[a, b]的一半。

.重复以上做法得新近似根x1,…这样不断将区间分半,得到一系列区间[an , bn],和近似根(区间中点)nx,n=0,1,2,3…,nx误差为(b-a)/2n+1.这样的方法称为二分法。

下面是一个关于二分法的例子。

例1求f(x)=x3- x-1=0在区间[1,1.5]内的一个实根,要求准确到小数点后的第二位.这里a=1,b=1.5,而f(a)<0,f(b)>0。

取[a,b]的中点x0=1.25,将区间二等分,由于f(x0 )<0, 既f(x0 )与f(a)同号,故所求的根x*必在x0 右侧,这是应令a1=x0 =1.25, b1=b=1.5,而得到新的有根区间[a1,b1],这样继续结果如下表:x6.实际上x5就有三位有效数字了.二分法实验(1)上机题目:二分法的应用实验目的:熟悉二分法并在计算机上实现实验要求:①上机前充分准备,复习有关内容,写出计算步骤,查对程序;②完成实验后写出完整的实验报告,内容应该包括:所用的算法语言,算法步骤陈述,变量说明,程序清单,输出计算结果,结果分析等等;③用编好的程序在Matlab环境中执行。

算法说明:①找出计算f(x)在有限根区间[a, b]端点的值,f(a),f(b)②计算计算f(x)在区间中点(2ba+)处的值f(2ba+) .③判断若f(2ba+)=0,则2ba+即是根,计算过程结束,否则检验若f(2ba+)f(a)<0,则以2ba+代替b,否则以2ba+代替a.反复执行步骤②和步骤③,直到区间[a, b]长度小于允许误差ξ,此时中点2ba+即为所求近似根。

二分搜索算法实验报告

二分搜索算法实验报告

二分搜索算法实验报告篇一:实验报告2--二分搜索技术注意:红色的部分需要用自己的代码或内容进行替换。

湖南涉外经济学院实验报告实验课程:算法设计与分析实验项目:二分搜索技术学院专业实验地点分组组号实验时间 XX年 3 月 10 日星期一第 12节指导老师【实验目的和要求】1. 理解分治法的原理和设计思想;2.要求实现二分搜索算法;3.要求交互输入一组关键字序列,输入需要查找的关键字;4. 要求显示结果。

【系统环境】操作系统:Windows XP 操作系统开发工具:VC++6.0英文企业版开发语言:C,C++【实验原理】1、问题描述给定已排好序的n个元素a[0…n-1],现要在这n个元素中找出一特定元素x。

2、实验原理二分搜索方法充分利用了元素间的次序关系(但也局限于此),采用分治策略,将n个元素分成个数大致相同的两半,取a[n/2]与x进行比较。

如果x=a[n/2],则找到x,算法终止。

如果xa[n/2],则只要在数组a的右半部继续搜索x。

【实验任务与步骤】1、实验步骤(可以根据自己的程序修改)(1) 实现顺序搜索。

(2) 实现二分搜索算法的递归算法。

(3) 实现二分搜索算法的非递归算法。

(4) 编写主函数,调用所写的三个算法进行测试,并进行输出。

2、源程序代码// 此处为解决问题的完整源程序,要求带注释,代码必须符合书写规范。

(1) 顺序搜索(2) 递归的二分搜索(3) 非递归的二分搜索(原文来自:小草范文网:二分搜索算法实验报告)……【实验结论(包括实验数据处理、问题与解决办法、心得体会、意见与建议等)】// 此处为程序运行的结果,要求有程序运行输入输出实例,要求至少有两组实验结果。

// 必须写心得体会、意见与建议等,或者遇到的问题、难题等。

……篇二:查找排序实验报告实验十:查找、排序计算机学院 12级2班 12110XX 李龙实验目的:1.掌握折半查找算法的思想。

2.实现折半查找的算法。

3.掌握常见的排序算法(插入排序、交换排序、选择排序等)的思想、特点及其适用条件。

基于matlab的实验报告

基于matlab的实验报告

基于matlab的实验报告实验报告:基于MATLAB 的实验一、实验目的通过使用MATLAB 软件,掌握如何进行数据分析、图像处理、算法实现等一系列实验操作,提高实验者的实践能力和动手能力。

二、实验原理MATLAB 是一种在科学计算和技术开发领域广泛应用的计算机软件。

它能进行矩阵计算、绘制函数和数据图像、实现算法以及进行数据分析等。

通过掌握MATLAB 的使用,能够快速、高效地解决各种科学和工程问题。

三、实验内容1. 数据分析:使用MATLAB 的数据分析工具进行数据的导入、处理和分析。

2. 图像处理:利用MATLAB 的图像处理工具包对图像进行滤波、增强、分割等操作。

3. 算法实现:使用MATLAB 实现常用的算法,如排序、搜索、图像压缩等。

四、实验步骤1. 数据分析:(1)使用MATLAB 的读取数据函数将数据导入MATLAB 环境中。

(2)利用MATLAB 的数据处理函数进行数据清洗和预处理。

(3)使用MATLAB 的统计工具进行数据分析,如求平均值、标准差等。

(4)利用MATLAB 的绘图函数将分析结果可视化。

2. 图像处理:(1)使用MATLAB 的读取图像函数将图像导入MATLAB 环境中。

(2)利用MATLAB 的图像处理工具包进行滤波操作,如均值滤波、中值滤波等。

(3)使用MATLAB 的图像增强函数对图像进行锐化、变换等操作。

(4)利用MATLAB 的图像分割算法对图像进行分割。

3. 算法实现:(1)使用MATLAB 编写排序算法,如冒泡排序、快速排序等。

(2)使用MATLAB 编写搜索算法,如二分查找、线性搜索等。

(3)使用MATLAB 实现图像压缩算法,如离散余弦变换(DCT)。

五、实验结果实验中,我们使用MATLAB 完成了数据分析、图像处理和算法实现的一系列实验操作。

通过数据分析,我们成功导入了数据并对其进行了清洗和预处理,最后得到了数据的统计结果。

在图像处理方面,我们对图像进行了滤波、增强和分割等操作,最终得到了处理后的图像。

算法设计与分析的实验报告

算法设计与分析的实验报告

实验一递归与分治策略一、实验目的1.加深学生对分治法算法设计方法的基本思想、基本步骤、基本方法的理解与掌握;2.提高学生利用课堂所学知识解决实际问题的能力;3.提高学生综合应用所学知识解决实际问题的能力。

二、实验内容1、①设a[0:n-1]是已排好序的数组。

请写二分搜索算法,使得当搜索元素x不在数组中时,返回小于x的最大元素位置i和大于x的最小元素位置j。

当搜索元素在数组中时,i和j相同,均为x在数组中的位置。

②写出三分搜索法的程序。

三、实验要求(1)用分治法求解上面两个问题;(2)再选择自己熟悉的其它方法求解本问题;(3)上机实现所设计的所有算法;四、实验过程设计(算法设计过程)1、已知a[0:n-1]是一个已排好序的数组,可以采用折半查找(二分查找)算法。

如果搜索元素在数组中,则直接返回下表即可;否则比较搜索元素x与通过二分查找所得最终元素的大小,注意边界条件,从而计算出小于x的最大元素的位置i和大于x的最小元素位置j。

2、将n个元素分成大致相同的三部分,取在数组a的左三分之一部分中继续搜索x。

如果x>a[2(n-1)/3],则只需在数组a的右三分之一部分中继续搜索x。

上述两种情况不成立时,则在数组中间的三分之一部分中继续搜索x。

五、实验结果分析二分搜索法:三分搜索法:时间复杂性:二分搜索每次把搜索区域砍掉一半,很明显时间复杂度为O(log n)。

(n代表集合中元素的个数)三分搜索法:O(3log3n)空间复杂度:O(1)。

六、实验体会本次试验解决了二分查找和三分查找的问题,加深了对分治法的理解,收获很大,同时我也理解到学习算法是一个渐进的过程,算法可能一开始不是很好理解,但是只要多看几遍,只看是不够的还要动手分析一下,这样才能学好算法。

七、附录:(源代码)二分搜索法:#include<iostream.h>#include<stdio.h>int binarySearch(int a[],int x,int n){int left=0;int right=n-1;int i,j;while(left<=right){int middle=(left+right)/2;if(x==a[middle]){i=j=middle;return 1;}if(x>a[middle])left=middle+1;else right=middle-1;}i=right;j=left;return 0;}int main(){ int a[10]={0,1,2,3,4,5,6,7,8,9};int n=10;int x=9;if(binarySearch(a,x,n))cout<<"找到"<<endl;elsecout<<"找不到"<<endl;return 0;}实验二动态规划——求解最优问题一、实验目的1.加深学生对动态规划算法设计方法的基本思想、基本步骤、基本方法的理解与掌握;2.提高学生利用课堂所学知识解决实际问题的能力;3.提高学生综合应用所学知识解决实际问题的能力。

信息检索课程实验报告

信息检索课程实验报告

一、实验背景随着信息技术的飞速发展,信息检索已成为信息时代的重要技能。

为了提高我们的信息素养,培养我们在海量信息中快速、准确地找到所需信息的能力,我们开展了信息检索课程实验。

本实验旨在让我们熟悉信息检索的基本流程,掌握各种检索工具的使用方法,并学会运用检索策略进行信息获取。

二、实验目的1. 熟悉信息检索的基本概念和流程。

2. 掌握搜索引擎和数据库的使用方法。

3. 学会运用检索策略提高检索效率。

4. 培养信息素养,提高信息获取能力。

三、实验内容1. 信息检索基本概念(1)信息检索:指根据信息用户的需求,利用一定的检索工具或联机网络,从大量的文献中迅速准确地查找、筛选、整理和利用所需信息的过程。

(2)检索工具:包括搜索引擎、数据库、图书馆等。

(3)检索策略:指在检索过程中,针对特定需求,选择合适的检索词、检索式和检索途径,以达到快速、准确地获取所需信息的目的。

2. 搜索引擎的使用(1)以百度为例,介绍搜索引擎的基本操作。

(2)演示如何利用关键词进行精确检索、组合检索和高级检索。

(3)讲解如何使用搜索技巧,如排除法、使用引号等。

3. 数据库的使用(1)以CNKI为例,介绍学术数据库的基本操作。

(2)演示如何利用数据库的高级检索功能,如主题检索、作者检索、机构检索等。

(3)讲解如何筛选和整理检索结果,提高信息获取效率。

4. 检索策略的应用(1)针对特定课题,分析检索需求,确定检索策略。

(2)运用关键词、布尔逻辑运算符、位置运算符等构建检索式。

(3)根据检索结果,调整检索策略,提高检索效果。

四、实验步骤1. 熟悉实验内容,了解信息检索的基本概念和流程。

2. 登录百度搜索引擎,进行关键词检索、组合检索和高级检索实验。

3. 登录CNKI学术数据库,进行主题检索、作者检索、机构检索等实验。

4. 根据实验需求,构建检索式,进行检索实验。

5. 分析检索结果,调整检索策略,提高检索效果。

6. 撰写实验报告,总结实验心得。

实验一 二分搜索算法

实验一  二分搜索算法

实验一二分搜索算法E08620311-方凯-08计算机(3)班一.实验目的:1、理解分治算法的概念和基本要素;2、理解递归的概念;3、掌握设计有效算法的分治策略;4、通过二分搜索技术学习分治策略设计技巧;二.实验内容及要求:1.使用二分搜索算法查找任意N个有序数列中的指定元素。

2.通过上机实验进行算法实现。

3.保存和打印出程序的运行结果,并结合程序进行分析,上交实验报告。

4.至少使用两种方法进行编程。

二.实验原理:二分搜索算法也称为折半查找法,它充分利用了元素间的次序关系,采用分治策略,可在最坏的情况下用O(log n)完成搜索任务。

【基本思想】将n个元素分成个数大致相同的两半,取a[n/2]与欲查找的x 作比较,如果x=a[n/2]则找到x,算法终止。

如果x<a[n/2],则我们只要在数组a的左半部继续搜索x(这里假设数组元素呈升序排列)。

如果x>a[n/2],则我们只要在数组a的右半部继续搜索x。

二分搜索法的应用极其广泛,而且它的思想易于理解。

第一个二分搜索算法早在1946年就出现了,但是第一个完全正确的二分搜索算法直到1962年才出现。

Bentley在他的著作《Writing Correct Programs》中写道,90%的计算机专家不能在2小时内写出完全正确的二分搜索算法。

问题的关键在于准确地制定各次查找范围的边界以及终止条件的确定,正确地归纳奇偶数的各种情况,其实整理后可以发现它的具体算法是很直观的。

方法一:直接查找;方法二:递归查找;方法三:迭代查找;四.程序代码:方法1:直接查找int BinarySearch(int a[],int x,int n){int left=0;int right=n-1;while(left<=right){int middle=(left+right)/2;if(x==a[middle])return middle;if(x>a[middle])left=middle+1;else right=middle-1;}return-1;}方法2:递归查找int BinarySearchDG(int a[],int x,int left,int right){int middle=(left+right)/2;if(left<=right){if(x==a[middle])return middle;if(x>a[middle])return BinarySearchDG(a,x,middle+1,right);else return BinarySearchDG(a,x,left,middle-1);}return-1;}五.结果运行与分析:for(int i=0;i<100;i++){a[i]=2*i-1;}我的数组是1,3,5,7,9……195,197所以57在数组的位置是29位,都没错。

实验四 搜索 实验报告

实验四 搜索 实验报告

实验四搜索实验报告一、实验目的本次实验的主要目的是深入了解和掌握不同的搜索算法和技术,通过实际操作和分析,提高对搜索问题的解决能力,以及对搜索效率和效果的评估能力。

二、实验环境本次实验使用的编程语言为 Python,使用的开发工具为 PyCharm。

实验中所需的数据集和相关库函数均从网络上获取和下载。

三、实验原理1、线性搜索线性搜索是一种最简单的搜索算法,它从数据的开头开始,依次比较每个元素,直到找到目标元素或者遍历完整个数据集合。

2、二分搜索二分搜索则是基于有序数组的一种搜索算法。

它每次将数组从中间分割,比较目标值与中间元素的大小,然后在可能包含目标值的那一半数组中继续进行搜索。

3、广度优先搜索广度优先搜索是一种图搜索算法。

它从起始节点开始,逐层地访问相邻节点,先访问距离起始节点近的节点,再访问距离远的节点。

4、深度优先搜索深度优先搜索也是一种图搜索算法,但它沿着一条路径尽可能深地访问节点,直到无法继续,然后回溯并尝试其他路径。

四、实验内容及步骤1、线性搜索实验编写线性搜索函数,接受一个列表和目标值作为参数。

生成一个包含随机数的列表。

调用线性搜索函数,查找特定的目标值,并记录搜索所用的时间。

2、二分搜索实验先对列表进行排序。

编写二分搜索函数。

同样生成随机数列表,查找目标值并记录时间。

3、广度优先搜索实验构建一个简单的图结构。

编写广度优先搜索函数。

设定起始节点和目标节点,进行搜索并记录时间。

与广度优先搜索类似,构建图结构。

编写深度优先搜索函数。

进行搜索并记录时间。

五、实验结果与分析1、线性搜索结果在不同规模的列表中,线性搜索的时间消耗随着列表长度的增加而线性增加。

对于较小规模的列表,线性搜索的效率尚可,但对于大规模列表,其搜索时间明显较长。

2、二分搜索结果二分搜索在有序列表中的搜索效率极高,其时间消耗增长速度远低于线性搜索。

即使对于大规模的有序列表,二分搜索也能在较短的时间内找到目标值。

3、广度优先搜索结果广度优先搜索能够有效地遍历图结构,并找到最短路径(如果存在)。

算法实验报告范文

算法实验报告范文

算法实验报告范文《算法设计与分析》实验报告班级姓名学号年月日目录实验一二分查找程序实现…………………………………………………………………03页实验二棋盘覆盖问题(分治法).…………………………………………………………08页实验三0-1背包问题的动态规划算法设计……………………………………………….11页实验四背包问题的贪心算法………………………………………………………………14页实验五最小重量机器设计问题(回溯法)………………………………………………17页实验六最小重量机器设计问题(分支限界法)…………………………………………20页指导教师对实验报告的评语成绩:指导教师签字:年月日2实验一:二分查找程序实现一、实验时间:2022年10月8日,星期二,第一、二节地点:J13#328二、实验目的及要求目的:1、用c/c++语言实现二分搜索算法。

2、通过随机产生有序表的方法,测出在平均意义下算法比较次数随问题规模的变化曲线,并作图。

三、实验环境平台:Win732位操作系统开发工具:Codeblock10.05四、实验内容对已经排好序的n个元素a[0:n-1],现在要在这n个元素中找出一特定元素某。

五、算法描述及实验步骤算法描述:折半查找法也称为二分查找法,它充分利用了元素间的次序关系,采用分治策略,可在最坏的情况下用O(logn)完成搜索任务。

它的基本思想是,将n个元素分成个数大致相同的两半,取a[n/2]与欲查找的某作比较,如果某=a[n/2]则找到某,算法终止。

如果某a[n/2],则我们只要在数组a的右半部继续搜索某。

二分搜索法的应用极其广泛,而且它的思想易于理解。

确定算法复杂度基本步骤:1、首先设定问题规模n;2、随即产生递增数列;3、在n个有序数中随机取一个作为待查找量,搜索之;4、记录查找过程中的比较次数,再次生成新的有序表并查找,记录查找次数,每个数组重复10次;5、改变问题规模n重复上述步骤2~4,n取100、200……1000;6、依实验数据作图,并与理论图作比较;7、二分搜索算法平均查找次数:问题规模为n时,平均查找次数为:A(n)=Int(logn)+1/2//Int()函数为向下取整3即二分搜索算法对于含有n个数据的有序表L平均作了约Int(logn)+1/2次的查找操作。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

竭诚为您提供优质文档/双击可除
二分搜索实验报告
篇一:算法设计与分析二分查找实验报告
课程设计说明书
设计题目:二分查找程序的实现
专业:班级:
设计人:
山东科技大学年月日
课程设计任务书
学院:信息科学与工程学院专业:班级:姓名:
一、课程设计题目:二分查找程序的实现二、课程设计主要参考资料
(1)计算机算法设计与分析(第三版)王晓东著(2)三、课程设计应解决的主要问题
(1)二分查找程序的实现(2)(3)四、课程设计相关附件(如:图纸、软件等):
(1)(2)
五、任务发出日期:20XX-11-21课程设计完成日期:20XX-11-24
指导教师签字:系主任签字:
指导教师对课程设计的评语
成绩:
指导教师签字:
年月日
二分查找程序的实现
一、设计目的
算法设计与分析是计算机科学与技术专业的软件方向的必修课。

同时,算法设计与分析既有较强的理论性,也有较强的实践性。

算法设计与分析的实验过程需要完成课程学习过程各种算法的设计和实现,以达到提高教学效果,增强学生实践动手能力的目标。

用分治法,设计解决二分查找程序的实现问题的一个简捷的算法。

通过解决二分查找程序的实现问题,初步学习分治策略。

二、设计要求
给定已按升序排好序的n个元素a[0:n-1],现要在这n 个元素中找出一特定元素x。

实现二分搜索的递归程序并进行跟踪分析其执行过程。

用顺序搜索方法时,逐个比较a[0:n-1]中的元素,直至找出元素x,或搜索遍整个数组后确定x不在其中。

这个方法没有很好的利用n个元素已排好序这个条件,因此在最坏情况下,顺序搜索方法需要o(n)次比较。

要求二分法的时间复杂度小于o(n)。

三、设计说明(一)、需求分析
二分搜索方法充分利用了元素间的次序关系,采用分治策略,可在最坏情况下用o(logn)时间完成搜索任务。

该算法的流程图如下:
(二)、概要设计
二分查(:二分搜索实验报告)找的基本思路是将n个元素分成大致相等的两部分,取a[n/2]与x做比较,如果
x=a[n/2],则找到x,算法终止;如果xa[n/2],则只要在数组a的右半部分继续搜索x。

由于二分查找的数组不一定是一个整数数组,所以我采用了c++中的模板函数,将排序函数sort和二分查找函数binarysort写为了模板函数,这样不尽可以查找整数数组,也可以查找小数数组。

由于查找的数组的长度不固定,所以我用了c语言中的malloc和realloc函数,首先定义一个数组指针,用malloc 函数该它分配空间,然后向数组中存数,当数组空间满时,在用realloc函数为数组再次分配空间。

由于在随机输入一
组数时不知在什么位置停止,所以
篇二:二分搜索实验报告
二分搜索
一.实验目的:
1.理解算法设计的基本步骤及各步的主要内容、基本要求;
2.加深对分治设计方法基本思想的理解,并利用其解决现实生活中的问题;
3.通过本次实验初步掌握将算法转化为计算机上机程
序的方法。

二.实验内容:
1.编写实现算法:给定n个元素,在这n个元素中找到值为key的元素。

2.将输入的数据存储到指定的文本文件中,而输出数据存放到另一个文本文件中,包括结果和具体的运行时间。

3.对实验结果进行分析。

三.实验操作:
1.二分搜索的思想:
首先,假设表中的元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将表分成前后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,
否则进一步查找后一子表。

重复上述过程,知道找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功。

由于二分搜索是基于有序序列的一种搜索算法,故将输入的一组数据首先进行排序,考虑到输入数据可能有多个,采用快速排或者是合并排序,其中与冒泡做了对比。

冒泡排序算法:
voidsort(intList[],intlength){
intchange;
for(inti=0;i for(intj=i+1;j
if(List[i]>List[j]){
change=List[i];
List[i]=List[j];
List[j]=change;
}
}
}
快速排序算法:
voidQsort(intList[],intlow,inthigh){
if(low>=high)return;
intfirst=low;
intlast=high;
intkey=List[first];
while(first while(first while(first } List[first]=key;
Qsort(List,low,first-1);
Qsort(List,last+1,high);}
二分查找算法:
intbinarysearch(intList[],intlow,inthigh,intkey){ intmid=(low+high)/2;
if(high while(low
if(List[mid]==key)returnmid+1;
else{
if(List[mid]>key)returnbinarysearch(List,low,mid-1, key);elsereturnbinarysearch(List,mid+1,high,key);
}
}
}
2.实验数据的输入:
本实验采用将数据输入与输出存储到文件中的方式,需要采用c++文件流操作,对于数据的输入,由于cin对数据的读取会忽略空格和换行操作,使用cin流输入来控制数据的输入。

对于输出操作,首先要从文件中读取数据,为了区别各数据,用逗号隔离,经过处理后将数据存入到另一文件之中。

由于输入需要大量的数据,可采用从“随机数.txt”中读取数据。

存入文件算法:
intinput(){
ofstreamoutFile;
outFile.open("e://程序设计/practice1/算法设计与分析文本文件夹D/number.txt",ios::trunc);
if(!outFile.is_open())cout cout charnumber;
intlength=0;
cin>>number;
while(number!=e){
length++;
outFile cin>>number;
}
outFile.close();
returnlength;
}
文件数据提取算法:
int*output(intlength){
ifstreaminFile;
ofstreamoutFile;inFile.open("e://程序设计
/practice1/算法设计与分析/文本文件夹
D/number.txt");
outFile.open("e://程序设计/practice1/算法设计与分析/文本文件
夹D/result2.txt",ios::trunc);
char*Array=newchar[length];
int*List=newint[length/2];
inti=0,j=0;
outFile while(!inFile.eof()){
inFile>>Array[i];
if(Array[i]!=,0;
outFile j++;
}
i++;
}
sort(List,length/2);
inFile.close();
outFile.close();
returnList;
}
3.程序运行时间测量:
为了得到二分搜索的时间,主要是排序的时间,调用time标准库,通过对起止时间记录,得到运行时间。

doublestart,end,Time;
start=clock();
调用程序;
end=clock();
Time=end-start;
四.实验数据分析:
当测试的数据较少时,如输入个数为20个时,两种排序时间都为0,即两种排序所消耗的时间差不多。

在数据小于2000个时,它们的耗费时间是代价相等的。

但当数据规模十分庞大时,快速排序的时间代价远远低于冒泡排序,例如当输入的数据为3000个时,快速排序的时间消耗是冒泡排序的1/3,由此可见一斑,并且当输入的数据完全逆序时,快速排序将和冒泡排序一样复杂。

最后将排序的时间与查找的时间相加,即为二分搜索的总时间,为
n(logn)+time.
五.实验感受:
在本次实验中,测试程序的运行时间时,需要用到大量的数据,仅仅输入100以内的数据对时间的测试不起作用,。

相关文档
最新文档