1) 顺序查找
逐个元素找,如果有,则记录位置,然后跳出循环;否则,查找失败。
代码如下:
Private Sub Search(a(), ByVal Key, Index As Integer)
Dim i%
For i = LBound(a) To UBound(a)
If a(i) = Key Then '找到,将元素下标保存在index中并结束查找
Index = i
Exit Sub
End If
Next i
Index = -1 '若没找到,则index值为-1
End Sub
2) 二分法查找
顺序查找效率低下,当数组有序排列时,可以使用二分法查找提高效率。
算法思想:
代码如下:
Private Sub birSearch(a(), ByVal low%, ByVal high%, ByVal Key, index%)
Dim mid As Integer
If low > high Then '没有查找到
index = -1
Exit Sub
End If
mid = (low + high) \ 2 '取查找区间的中点
If Key = a(mid) Then '查找到,返回下标
index = mid
Exit Sub
ElseIf Key < a(mid) Then '查找区间在上半部分
high = mid - 1
Else
low = mid + 1 '查找区间在下半部分
End If
Call birSearch(a, low, high, Key, index) '递归调用查找函数
End Sub
【VB常用算法(八)查找】相关文章:
Vb中控件的自动排列05-09
2016年职称英语综合类阅读判断练习八05-09
2023年广东梅州中考成绩查询时间及查分入口[7月7日起]05-09
2021湖北黄冈市浠水县基层医疗卫生机构专项招聘医务人员资格审查公告05-09
法院上半年工作总结05-09
2018湖南省农村信用社联合社招聘科技专业人才拟聘公告05-09
at(the)least和not(in)the least用法区别 相似词语辨析(17)05-09
普通中学生入团志愿书500字通用范文05-09
计算机应用技术英语简历范文大全05-09
党员四风问题自查材料05-09
