浙江大学数据结构(3.1.3引子(二分查找实现))

二分查找法

int BinarySearch(List Tbl,ElementType K)
{
 int left,right,mid,NotFound=-1;
 left=1; // 数组从下标为一的位置开始存放
 right=Tbl->length;
 while (left<=right)
       {
        mid=(left+right)/2;
        if (K<Tbl->Element[mid])
           right=mid-1;
        else if (K>Tbl->Element[mid])
                left=mid+1;
        else return mid; 
       }
 return NotFound;
}
  • 二分查找算法具有对数的时间复杂度O(logN)

11个元素的二分查找判定树

  • 判定树上每个结点需要的查找次数刚好为该结点所在的层数;
  • 查找成功时查找次数不会超过判定树的深度
  • n个结点的判定树的深度为[log2n]+1
  • AvergeSearchLength=(4*4+4*3+2*2+1)/11=3

二分查找的启示?

  • 以树的方式存储数据,以便查找
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值