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

算法——二分查找

介绍

二分查找是一个高效的查找算法,查找算法还有线性查找,它的时间复杂度为 O ( n ) O(n) O(n),但二分查找的时间复杂度为 l o g ( n ) log(n) log(n)(因为是2分,所以此处的log是以2为底的对数函数)。

注:本文提到的查找都是无重复元素的,要是有重复元素,就比较麻烦了。

线性查找

思想

从数组的头部向尾部遍历,如果找到就返回它的下标,如果遍历完还找不到就返回-1。

代码

class Solution {public int linearSearch(int[] nums, int target) {for (int i = 0; i < nums.length; i++) {if (nums[i] == target) {return i;}}return -1;}
}

二分查找

前提

数组是有序的,一般要求数组为升序排列,也就是从小到大排列。

思想

二分查找的核心思想就是分治就是将一个问题划分为多个子问题,就是将最小的子问题解决。比如说有一堆苹果,要想吃完这堆苹果(解决一个大问题),就得先将这堆苹果分成很多堆(将问题划分为子问题),直到每堆只剩一个苹果(划分到了最小的子问题),然后再一个一个地将苹果吃掉(将最小的子问题解决)。

现在理解二分查找,二分查找就是找到升序的数组的中间元素,然后比较中间元素与目标元素的大小,如果目标元素等于中间元素,则直接返回中间元素的下标;如果目标元素大于中间元素,就去右子区间查找;否则就去左子区间查找。直到找到目标元素无法再找为止(无法再找指的是区间的长度小于1)。注意,如果数组是降序的,则策略与此恰好相反。

由于二分查找每次都将待查找区间缩小为上一个待查找区间的一半,所以它的时间复杂度为 O ( l o g n ) O(logn) O(logn)

代码

class Solution {public int binarySearch(int[] nums, int target) {// nums一定要有序,如果没有序,就先使用Arrays.sort(nums);将nums按升序排列int left = 0, right = nums.length - 1;while (left <= right) {int mid = left + (right - left >> 1);if (nums[mid] == target) {return mid;} else if (nums[mid] < target) {left = mid + 1;} else {right = mid - 1;}}return -1;}
}

相关文章:

  • 开关电源中电感设计
  • R语言探索与分析14-美国房价及其影响因素分析
  • Codeforces Round 951 (Div. 2) D. Fixing a Binary String 题解
  • Linux系统之部署Blog-Index导航页
  • nginx c++模块编译
  • 【JS重点知识05】正则表达式
  • java基础练习题
  • Web前端与REST API:深度解析与实战指南
  • vue antdesgin table 动态表头动态数据示例
  • [AIGC] SpringBoot的自动配置解析
  • Faiss assertion ‘err == cudaSuccess‘ failed in void faiss::gpu:runL2Norm()
  • STM32/keil把多个c文件编译为静态库lib
  • C++的算法:拓扑排序的原理及应用
  • WWDC 2024前瞻:苹果如何用AI技术重塑iOS 18和Siri
  • VMware ESXi 8.0U2c macOS Unlocker OEM BIOS 集成网卡驱动 Marvell AQC 网卡定制版
  • 「面试题」如何实现一个圣杯布局?
  • Angular数据绑定机制
  • DOM的那些事
  • Elasticsearch 参考指南(升级前重新索引)
  • LeetCode541. Reverse String II -- 按步长反转字符串
  • PHP面试之三:MySQL数据库
  • React 快速上手 - 06 容器组件、展示组件、操作组件
  • spring boot 整合mybatis 无法输出sql的问题
  • swift基础之_对象 实例方法 对象方法。
  • Vue2 SSR 的优化之旅
  • vuex 学习笔记 01
  • ------- 计算机网络基础
  • 开源地图数据可视化库——mapnik
  • 前端性能优化--懒加载和预加载
  • 前端之React实战:创建跨平台的项目架构
  • 如何优雅地使用 Sublime Text
  • 十年未变!安全,谁之责?(下)
  • 使用Maven插件构建SpringBoot项目,生成Docker镜像push到DockerHub上
  • 它承受着该等级不该有的简单, leetcode 564 寻找最近的回文数
  • 通过git安装npm私有模块
  • 学习笔记:对象,原型和继承(1)
  • 用Canvas画一棵二叉树
  • 用mpvue开发微信小程序
  • 最近的计划
  • HanLP分词命名实体提取详解
  • 回归生活:清理微信公众号
  • 数据可视化之下发图实践
  • ​【原创】基于SSM的酒店预约管理系统(酒店管理系统毕业设计)
  • #java学习笔记(面向对象)----(未完结)
  • #绘制圆心_R语言——绘制一个诚意满满的圆 祝你2021圆圆满满
  • #我与Java虚拟机的故事#连载15:完整阅读的第一本技术书籍
  • (+3)1.3敏捷宣言与敏捷过程的特点
  • (33)STM32——485实验笔记
  • (BAT向)Java岗常问高频面试汇总:MyBatis 微服务 Spring 分布式 MySQL等(1)
  • (PySpark)RDD实验实战——取一个数组的中间值
  • (初研) Sentence-embedding fine-tune notebook
  • (分享)一个图片添加水印的小demo的页面,可自定义样式
  • (附源码)ssm本科教学合格评估管理系统 毕业设计 180916
  • (附源码)小程序儿童艺术培训机构教育管理小程序 毕业设计 201740
  • (过滤器)Filter和(监听器)listener