IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 二分法浅谈 -> 正文阅读

[数据结构与算法]二分法浅谈

前言

最近在做力扣的 14 天计划 「算法」 - 学习计划 - 力扣(LeetCode)全球极客挚爱的技术成长平台 (leetcode-cn.com)

然后第一天就是 二分查找

704. 二分查找 - 力扣(LeetCode) (leetcode-cn.com)

278. 第一个错误的版本 - 力扣(LeetCode) (leetcode-cn.com)

35. 搜索插入位置 - 力扣(LeetCode) (leetcode-cn.com)

虽然题目难度不大,但是还是得惊呼一声好家伙

然后发现了之前长期未解决并暴露的问题:

什么时候用left<right?什么时候用left<=right?

搜索的区间如何定义?

(left+right)/2 溢出如何解决?

循环条件?

当循环条件为 < 时

循环跳出后所得的结果为 left == right 。这时候,left 与 right 就夹出了唯一的位置,这个位置就是目标值的位置,或者说是如果这个元素存在,应该在的位置。更值得一提的是, left == right 时,返回 left,right 都行,因为它两值相等。因此可以判断元素存在时的位置。

当循环条件为 <= 时

循环跳出后所得的结果为 left > right 。这时候,left 与 right 就走过头了,此时就表明该元素不存在。因此可以判断元素存不存在

搜索的区间如何定义?

初始区间应该能够覆盖到所有可能返回的结果。下界是 0 是显然的,但是上界是 n 还是 n-1 取决于元素可不可能比所有序列中元素都大?都大则为 n

溢出如何解决?

mid = left + (right - left)/2 可以避免溢出

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-08-26 12:21:37  更:2021-08-26 12:22:55 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 23:26:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码