如何实现数组的二分查找
二分查找是一种极其高效、简练的查找算法,它不仅简单,易用,而且还非常的高效。相对于顺序查找,二分查找在效率是呈现指数性提升,数据量越大,越能体现出二分查找法的优势。
二分查找的查找过程是:先确定待查找元素所在线性表的范围,然后逐步缩小范围直到找到(或找不到)该元素为止。
二分查找算法要求数据必须是有顺序的排序,即要么是升序排列,要么是降序排列。因此,在使用二分查找法前,需要将数组处理为有序数组。
案例说明
关键技术
利用do循环结构语法,每次循环时查找一个中间值,并判断是否是要找的内容,如果是则结束循环,否则修改中间值,继续查找,直到找到指定内容,或者查询完毕。
设计过程
步骤一
按照下图完成程序界面的搭建。
步骤二
首先,需要在代码区顶部声明一个全局数组arr(1000)
Option ExplicitDim arr(1000) As Long
步骤三
然后,编写窗体加载的代码,在这里我们为arr数组赋予一个初始的内容。
Private Sub Form_Load()Dim i As Long'给数组分配内容For i = 1 To 1000= i * 2Next iEnd Sub
步骤四
接着,我们编写查询按钮的代码。
Private Sub Command1_Click()Dim low%, hight%, mid%Dim flag As Boolean '是否查询到内容的标记'给下标、上标和中间值初始值low = 1hight = 1000mid = (low + hight) / 2flag = False'开始查找Do While (flag = False And hight >= low)If arr(mid) = Text1 ThenMsgBox "找到该数,下标为:" & midflag = TrueExit DoElseIf arr(mid) > Val(Text1) Thenhight = mid - 1Elselow = mid + 1End Ifmid = (low + hight) / 2DoEventsLoopIf flag = False Then MsgBox "未查询到该数"End Sub
步骤五
最后,我么来进行测试。运行程序,输入一个要查找的数值,然后点击查询按钮。
总结
数组在VB中具有非常非常重要的作用,对于处理数据具有绝对的优势,因此掌握数组的基本操作,尤其是增加、删除和插入以及查询都是相当重要的。小伙伴们一定要勤加练习哦。
友情提示:
