算法:二分搜索

二分是个什么东西

二分当然是个好东西~

它可以代替暴力,说白了二分就是暴力的优化版,二分是这样工作的,比如现在在1、2、3、4、5、6、7、9、11这个有序序列里寻找2(注意!二分搜索只适用于有序的序列),首先找到左指针l和右指针r之间中间位置上数mid,这时mid=5,判断我们要找的数大于小于还是等于当前这个数,如果大于当前这个数,那么是不是要找的数就在后面(也就是左指针l=mid+1)?当然2比五小,那么就应该在前面的区间搜索(也就是右指针r=mid-1),我们找到前面区间的中间值2与目标比较(此时mid=2),2等于2,那么就找到了2的位置。

这就是二分搜索

总结一下,二分搜索步骤如下(本人很懒,不想把代码敲出来了,大家自己回去编出来):

1、定义左指针l和右指针r

2、定义l和r之间的中间位置mid

3、判断a[mid]是否等于要查的数(a是被查询的数组,从小到大排列)

4、判断成功的话就输出。

5、判断失败的话,就判断当前位置上的数是否大于mid。

6、如小于mid,则r=mid-1,否则l=mid+1

这篇文章短是短了点,但是二分的精华全包括在内了,反正虽然没详解,但是二分里的内容也讲了个大概,所以给个赞呗

相关推荐
0 0 04 分钟前
CCF-CSP 37-2 机器人饲养指南(apple)【C++】考点:完全背包问题
开发语言·c++·算法
xiaoye-duck6 分钟前
《算法题讲解指南:优选算法-分治-归并》--49.计算右侧小于当前元素的个数,50.翻转对
c++·算法
_Twink1e6 分钟前
[算法竞赛]八、排序、排列
数据结构·c++·笔记·算法·排序算法
im_AMBER7 分钟前
Leetcode 137 组合 | 电话号码的字母组合
开发语言·算法·leetcode·深度优先·剪枝
Alex艾力的IT数字空间8 分钟前
OCR 原理:从像素到文本的智能转换
数据结构·人工智能·python·神经网络·算法·cnn·ocr
仟濹13 分钟前
【算法打卡day19(2026-03-11 周三)算法:打家劫舍-DP,双指针,二分查找,滑动窗口,方向控制,前缀和 】8个题
算法·leetcode·二分查找·动态规划
未来之窗软件服务13 分钟前
自己写算法(十)js加密UUID保护解密——东方仙盟化神期
java·javascript·算法·代码加密·东方仙盟算法
样例过了就是过了14 分钟前
LeetCode热题100 腐烂的橘子
数据结构·c++·算法·leetcode·bfs
Chan1622 分钟前
LeetCode 热题 100 | 链表
java·数据结构·spring boot·算法·leetcode·链表·java-ee
程序员小明儿23 分钟前
量子计算探秘:从零开始的量子编程与算法之旅 · 第五篇
算法·量子计算