实验报告
课程名称 《算法分析与设计》
实验日期 2021年 3 月 22 日 至 2021年 3 月 28日
实验名称
实验三:两种检索算法
实验地点 同组人员 无
- 问题
写出两种检索算法:在一个排好序的数组T[1…n]中查找x,如果x在T中,输出x在T的下标j;如果x不在T中,输出j=0. - 解析
选择两种检索算法,分别为顺序查找以及二分法查找,示例有序数组为 a[10]={0,1,2,3,4,5,6,7,8,9};
①顺序查找。对所有元素按顺序进行遍历,与查找数x作比较,找到时退出输出该元素下标,遍历完成时没有找到则输出下标为0。
②二分法查找。设定left,right,mid三变量分别指向数组的下界,上界,中间。初始值为mid=(left+right)/2,将其与要查找的x作比较,如果a[m]<x,则下界left=m+1,反之上界更新为right=m-1;不断缩小范围直到找到x或left>right,遍历结束。
其中Flag标记是否找到。 - 设计
[核心伪代码]
①顺序查找
for(遍历数组)
{
if(找到){
输出下标;
Flag=1;//记录已找到
break;
}
}
②二分法查找:
while(遍历数组)
{
设中间值m为上下之和/2
if(m<x){
下更新为m+1}
else if(m>x){
上更新为m-1
}
else//找到{
输出数组下标;
Flag=1;//记录已找到
break;
}
} - 分析
[算法复杂度推导]
设n个元素:
①顺序查找:一个for(n)内嵌套一个if语句,可得时间复杂度T(n)=O(n);
②二分法查找:假设最差的情况,二分后的查找区间为n/2,n/4…n/2k,直到n/(2k)=1,则循环次数为k=log2n,也可根据主定理T(n)=T(n/2)+O(1),因此时间复杂度为T(n)=O(log2n); - 源码
[github源码地址]
https://github.com/zjk715/–homework