当前位置: 首页 > article >正文

2025寒假备战蓝桥杯01---朴素二分查找的学习

文章目录

  • 1.暴力方法的引入
  • 2.暴力解法的思考 与改进
  • 3.朴素二分查找的引入
  • 4.朴素二分查找的流程
  • 5.朴素二分查找的细节
  • 6.朴素二分查找的题目

1.暴力方法的引入

对于下面的这个有序的数据元素的组合,我们的暴力解法就是挨个进行遍历操作,一直找到和我们的这个target一样的这个元素才终止;

image-20250119234416611

2.暴力解法的思考 与改进

上面的暴力解法试过之后,我们会发现,上面的解法每次只能干掉一个元素,但是如果我们指定某一个元素,比如下面的这个4,这个时候4<5,我们直接往后面看就可以了,前面的全部都被干掉了,这个就是对于上面的暴力解法的这个改进;

image-20250119234534642

3.朴素二分查找的引入

上面可以得知,我们是找一个随机元素,我们的二分查找是取中间的这个元素,但是按照上面的思路,我们可以去任意元素,可以是1/3分段点,或者是1/4分段点,但是只有这个二分查找保留了下来,并没有类似于这个三份,四分之类的;

这个主要是使用数学推导之后就可以发现,当取这个中间元素的时候,我们的这个时间复杂度是最低的;

4.朴素二分查找的流程

下面的这个就是有序数组的这个查找的流程,学过c语言或者数据结构的对于这个应该很熟悉,在此不多言了;

image-20250119234934941

5.朴素二分查找的细节

1)循环的结束:我们的这个left==right的时候,这个还是需要继续进行判断的,直到left>right;

2)根据这个每次取中的原理,可以知道每一次就看到了一半的元素,以此类推求解这个时间复杂度,如图所示;

image-20250119235051358

6.朴素二分查找的题目

image-20250119235231988

1)思路和我们上面的描述就是一致的,不多言了;

2)对于这个mid的取值,本来是可以直接使用这个(left+right)/2计算的,但是这个里面的使用的left+区间长度的一半,这个主要是考虑栈溢出的风险,使用减法巧妙处理掉这个问题;

+区间长度的一半,这个主要是考虑栈溢出的风险,使用减法巧妙处理掉这个问题;

image-20250119235312987


http://www.kler.cn/a/511075.html

相关文章:

  • SQL-leetcode—626. 换座位
  • 信息奥赛一本通 1168:大整数加法
  • [JavaScript] 运算符详解
  • 使用 Java 和 FreeMarker 实现自动生成供货清单,动态生成 Word 文档,简化文档处理流程。
  • 医院挂号就诊系统设计与实现(代码+数据库+LW)
  • Apache Hive--排序函数解析
  • 第15章:Python TDD应对货币类开发变化(二)
  • AIGC视频生成模型:Meta的Emu Video模型
  • 嵌入式硬件篇---PWM电机舵机
  • Unix 与 Linux 深度应用与对比分析
  • 搭建openharmony Docker编译环境
  • 【STM32HAL-----GPIO】
  • 25. 【.NET 8 实战--孢子记账--从单体到微服务】--记账模块--预算金额的币种转换
  • VIT论文阅读与理解
  • 函数递归的介绍
  • 深入了解生成对抗网络(GAN):原理、实现及应用
  • 《CPython Internals》阅读笔记:p232-p249
  • React 第三方状态管理库相关 -- Recoil Zustand 篇
  • 基于 WEB 开发的汽车养护系统设计与实现
  • docker运行镜像命令
  • 论文笔记(六十二)Diffusion Reward Learning Rewards via Conditional Video Diffusion
  • Spring Boot中yml和properties的区别
  • 进阶——第十六届蓝桥杯熟练度练习(串口)
  • rook-ceph云原生存储解决方案
  • 洗衣店订单|基于springboot+vue的洗衣店订单管理系统(源码+数据库+文档)
  • 【博客之星评选】2024年度前端学习总结