算法 Class 006(二分搜索)

一、查找一个数

在一个有序数组中查找数字,每次一循环可 砍掉一半的值,只要确定了 arr[mid] 与 num 之间的关系。

大于num 忽略掉 mid及右边的数字

小于 num 忽略掉 mid 及左边的数字

二、 找大于等于 num 的最左位置

意思就是该下标及右边的数都是大于等于 num 的

与上面找一个数的区别 ,就是多用一个变量去记下标,如果

arr[mid] 大于等于 num,此时 mid 右边的都是满足的,修改右边界,记一次下标

arr[mid] 小于 num ,此时 mid 左边都是小于 num 的,修改边界即可。

然后写个暴力查找(遍历而已),用Class 005 的内容 验证,可得出上 code大概率是对的

对数器。

后期的优化思想是 ,如果失败了,拷贝一份当前数组的的内容,拷贝 a1,a2的值,方便调试看看是哪儿出了问题,因为刚才就出问题了,然后在else 代码块那里打了个断点,然后直接 Fn + F5(我用的笔记本),跳转到断点,然后观看监视窗口,发现了错误(这样感觉也行,主要是怕监视窗口也看不出错误),就得拷贝数据,观察一下了。


找 小于等于 num 最右边的下标,需要修改一下判断和小于等于记 坐标就行

相关推荐
爱笑的Sunday1 小时前
【LeetCode 题解】算法:15.三数之和
java·数据结构·算法·leetcode
我想吃余2 小时前
【初探数据结构】二叉树的顺序结构——堆的实现详解(上下调整算法的时间复杂度分析)
数据结构·算法
Phoebe鑫2 小时前
数据结构每日一题day2(顺序表)★★★★★
数据结构·算法·leetcode
lwewan3 小时前
26考研——图_图的代码实操(6)
数据结构·笔记·考研·算法·深度优先
aimmon3 小时前
Rust从入门到精通之入门篇:8.基本数据结构
开发语言·数据结构·rust
十五年专注C++开发5 小时前
双指针技巧在C++中的应用:从基础到进阶
开发语言·数据结构·c++
王RuaRua5 小时前
[数据结构]1.时间复杂度和空间复杂度
c语言·数据结构·算法
愚戏师6 小时前
C++:泛型算法
开发语言·数据结构·c++·算法
昂子的博客7 小时前
热门面试题第14天|Leetcode 513找树左下角的值 112 113 路径总和 105 106 从中序与后序遍历序列构造二叉树 (及其扩展形式)以一敌二
java·数据结构·算法·leetcode·职场和发展
G皮T7 小时前
【Python Cookbook】字符串和文本(二)
数据结构·python·算法·字符串