作业333

这篇实验报告详细介绍了在有序数组中进行检索的两种算法——顺序查找和二分法查找。顺序查找的时间复杂度为O(n),而二分法查找的时间复杂度为O(log2n)。实验通过伪代码展示了这两种算法的实现,并提供了GitHub源码链接供参考。
摘要由CSDN通过智能技术生成

实验报告

课程名称 《算法分析与设计》
实验日期 2021年 3 月 22 日 至 2021年 3 月 28日

实验名称
实验三:两种检索算法
实验地点 同组人员 无

  1. 问题
    写出两种检索算法:在一个排好序的数组T[1…n]中查找x,如果x在T中,输出x在T的下标j;如果x不在T中,输出j=0.
  2. 解析
    选择两种检索算法,分别为顺序查找以及二分法查找,示例有序数组为 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标记是否找到。
  3. 设计
    [核心伪代码]
    ①顺序查找
    for(遍历数组)
    {
    if(找到){
    输出下标;
    Flag=1;//记录已找到
    break;
    }
    }
    ②二分法查找:
    while(遍历数组)
    {
    设中间值m为上下之和/2
    if(m<x){
    下更新为m+1}
    else if(m>x){
    上更新为m-1
    }
    else//找到{
    输出数组下标;
    Flag=1;//记录已找到
    break;
    }
    }
  4. 分析
    [算法复杂度推导]
    设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);
  5. 源码
    [github源码地址]
    https://github.com/zjk715/–homework
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值