[Visual Basic]二分查找
模板
i=1:j=n 'i初值为1,j初值为n
Do while i<=j '当i<=j时,通过循环进行查找
m=fix((i+j)/2) '计算出中间元素的下标m
If d(m)=key Then '若中间元素d(m)和key相等,则输出m;退出循环
print m
Exit Do
End If
If d(m)<key Then
i=m+1 '[m+1,j]下一查找范围
Else
j=m-1 '[i,m-1]
End If
Loop
If i>j Then print"0" '未找到
注意点及变式
查找次数:LogN(若不是整数,则向上取整)
计算中间元素的下标的方法有很多种,是选择题中小小的坑(我掉进去好多次了)
'e.g.
'偶数组 1 2 3 4 5 6 7 8
'奇数组 1 2 3 4 5 6 7 8 9
'偶数组 i=1:j=8 奇数组 i=1;j=9
' 偶数组 奇数组 备注
① Int((i+j)/2) ' 4 4 删除小数部分而返回剩下的整数
② Fix((i+j)/2) ' 4 4
③ (i+j)/2 ' 4.5 5 Dim c as integer c=(i+j)/2=4
④ (i+j)\2 ' 4 5 选择左数或中间数
⑤ (i+j+1)/2 ' 5 5 选择右数或中间数
⑥ Fix((i+j)/2 +0.5)'
一般而言题目多为选择左数与中数。
还要看清数组编号是0开始还是1开始,在高中试卷里是1开始为多
二叉树法
qwq图片是从老师课件里白嫖来哒(溜
例题:
有如下VB程序段:
i = 1 : j = 10 : flag = True : n = 0
Key = Val(Text1.Text)
Do While i <= j And flag = True
m = (i + j) \ 2
If a(m) = Key Then
flag = False
Elseif a(m) > Key Then
i = m + 1 : n = n - 1
Else
j = m - 1 : n = n + 1
End If
Loop
数组元素a(1)到a(10)依次是99, 94, 90, 87, 70 , 69 , 60 , 56 , 45 , 36 ,变量n的值最终是0,则文本框Text1输入的数字可能是
A.100 B.87 C.69 D.4
用二叉树解题的最明显的特征就是n=n-1;n=n+1,在本题中前者的含义是“当需要查找的值Key比二分点要小,则向右查找,并且n-1”(数据是降序),后者反之亦然。
n=向左缩进的次数-向右缩进的次数
所以模拟出下面的一棵二叉树(蓝字为数,红字为n)

很容易看出n=0时,所查数为69、70、90.故题目的答案为C
以上是很基本的裸题,先来看看注意点:
- 数字排序升or降?什么时候n+1或是n-1?
- 查找到数时程序是否继续进行
本题中采用了Flag与If、ElseIf、Else,还有Exit For也能达到找到就会停止程序的目的。如果代码中缺少上面的语句,如两个If且不带Exit For、只有If与Else,程序继续,n的值仍然会改变,这时候就还要继续画二叉树了 - 选项中有大于最大值和小于最小值的数
就是题中的A100与D4,图中已画出。需要在原二叉树(仅数列)的最左侧与最右侧扩展开,具体见图。 - 变式:求n满足0时输入数据的范围
Answer:(Loading……)这块地方我也还不懂……如果你会的话可以来教教我吗……
暂时想到的难点就这些了,如果后面写题目又遇到新的,会继续更新。欢迎纠正哦~
小花絮:写博客时问老师题目的截图(肯定又是和lp过节去了哼这个男人略略略)


[Visual Basic]二分查找的更多相关文章
- 基于visual Studio2013解决面试题之1307二分查找
题目
- 《Visual Basic开发实战1200例》包括第I卷、第II卷共计1200个例子,本书是第I卷,共计600个例子。
本书以开发人员在项目开发中经常遇到的问题和必须掌握的技术为中心,介绍了应用Visual Basic进行程序开发各个方面的知识和技巧.主要包括基础知识.窗体界面设计.控件应用等.全书分6篇20章,共计6 ...
- 演练:Office 编程(C# 和 Visual Basic)
https://msdn.microsoft.com/zh-cn/library/ee342218(v=vs.110).aspx PIA的全称是 primary interop assembly 主 ...
- VS2017远程调试C#或 Visual Studio 中的 Visual Basic 项目
来源:远程调试C#或 Visual Studio 中的 Visual Basic 项目 若要调试已部署在另一台计算机的 Visual Studio 应用程序,安装和在其中部署您的应用程序的计算机上运行 ...
- Visual Basic 2017 操作Excel和word【1】持续更新……
我坚持在VB的路上走到黑………… 清单1.1 从应用程序对象导航到Excel中的工作表 Dim myWorkbooks As Excel.Workbooks = app.Workbooks ) ...
- 常用算法1 - 快速排序 & 二分查找
1. 二分查找法: 二分查找法是对一组有序的数字中进行查找,传递相应的数据,进行比较查找到与原数据相同的数据,查找到了返回对应的数组下标,没有找到返回-1. 二分查找法要求数据为一组有序的序列(大到小 ...
- 【C/C++学院】0723-32位与64位/调戏窗体程序/数据分离算法/内存检索/二分查找法/myVC
[送给在路上的程序猿] 对于一个开发人员而言,能够胜任系统中随意一个模块的开发是其核心价值的体现. 对于一个架构师而言,掌握各种语言的优势并能够运用到系统中,由此简化系统的开发,是其架构生涯的第一步. ...
- 二分查找算法java
二分查找又称折半查找,它是一种效率较高的查找方法. 折半查找的算法思想是将数列按有序化(递增或递减)排列,查找过程中采用跳跃式方式查找,即先以有序数列的中点位置为比较对象,如果要找的元素值小于该中点元 ...
- 数据结构实验7:实现二分查找、二叉排序(查找)树和AVL树
实验7 学号: 姓名: 专业: 7.1实验目的 (1) 掌握顺序表的查找方法,尤其是二分查找方法. (2) 掌握二叉排序树的建立及查找. 查找是软件设计中的最常用的运算,查找所涉及到 ...
随机推荐
- jquery.Table实现的翻页功能比较完整漂亮,本想扩展个模版DIV
jquery.dataTable实现的翻页功能比较完整漂亮,本想提取其的翻页部分,再结合模版DIV,bootstrop实现聊天记息的展示. jquery.Table 与table结合的较紧,不能在很下 ...
- Java 判断字符串是否包含某个字符
// 判断不为静态栏目的文章 if (e.getCategory().getName().indexOf("静态") == -1) { articleList2.add(e); } ...
- springboot oauth 鉴权之——password、authorization_code鉴权
参考一下两个案例:https://www.cnblogs.com/haoliyou/p/9606018.html https://www.cnblogs.com/haoliyou/p/9606036. ...
- Tozan and Gezan(x*y<a*b)
E - Tozan and Gezan Time limit : 2sec / Memory limit : 256MB Score : 700 points Problem Statement Yo ...
- AI未来如何应对人类的欺骗?
人工智能正以可预见.不可预见的种种形式无孔不入地涉足社会的各个层面,这既让人兴奋,也让人不安.我们能够预测到这样的情绪反应,但我们真的能够预测到人工智能所涉及的相关风险吗? 假若现在是2022年,你乘 ...
- Java2变量和运算符
课后作业:[必做题] 1√AB互换 已知a,b均是整型变量,写出将a,b两个变量中的值互换的程序.(知识点:变量和运算符综合应用) [必做题] package com.two; public clas ...
- MySQL root密码重置问题
1:进入cmd,停止mysql服务:Net stop mysql (进入服务---->MySql----->停止) 到mysql的安装路径启动mysql,在bin目录下使用mysqld-n ...
- PHP网络爬虫实践:抓取百度搜索结果,并分析数据结构
百度的搜索引擎有反爬虫机制,我先直接用guzzle试试水.代码如下: <?php /** * Created by Benjiemin * Date: 2020/3/5 * Time: 14:5 ...
- 解决WebMvcConfigurer下的addViewControllers无法找到制定页面
解决WebMvcConfigurer下的addViewControllers无法找到制定页面 这种都已经配置了拦截跳转,但无效的原因是,没有加载thymeleaf依赖 <dependency&g ...
- 服务器推送 SSE 了解一下?
hello~亲爱的看官老爷们大家好~过完年第一周已经结束,是时候开始制定新的工作计划了.主要负责的项目是数据可视化平台,而使用中如果服务器能有推送能力让页端得到相关通知的话,就能实现很多功能上的优化. ...