算法导论读书笔记:二分查找及基于二分查找策略的插入排序算法

练习2.3-5 问题描述:如果序列A是已排序的,将该序列的中点与v进行比较。根据比较的结果,原序列有一半就可以不用再作进一步的考虑了。二分查找(binarysearch)就是一个不断重复这一查找过程的算法,他每次都将序列余下的不分分成两半,并对其中一半做进一步你的查找。写出二分查找算法的伪代码。

递归二分查找算法:

BINARY-SEARCH(A, v, p, r)
If r > p then
j ← A[(r - p)/2]
end
if v = A[j]then
    return j
else
    if v < A[j] then
      return BINARY-SEARCH (A, v, p, j)
   else
      return BINARY-SEARCH (A, v, j, r)
    end
end


 

练习2.3-6 问题描述 在插入排序中,采用了一种线性查找策略,即在已排好的子数组A[1,…, j-1] 中反向扫描。问是否可以改用二分查找策略,来将插入排序的总体最坏情况运行时间改善至

将插入排序的顺序查找改为二分查找的算法:

INSERTION-BINARY-SORT(A)
for j ← 2 to length(A)
    key ← A[j]
       △insert A[j] into the sorted sequence A[1, … ,j-1]
   high ← 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值