算法===二分查找

devtools/2024/10/22 16:47:33/

文章目录

  • 概要
  • 定义
  • 代码Python
  • 小结

概要

二分,很常用,不管是日常生活,还是工作,学习;哪怕是使用计算机查下哪块占了硬盘空间,都用的上。

二分,太常用了。比如,我的电脑某一个盘慢了,查哪占了硬盘的内存;怎么办呢?直接选择所有文件夹,然后看下总大小;分成一半,看占多数,这么找下去,用不了多久,就能找到哪个文件最占硬盘空间。

定义

二分的定义,来学习学习

二分查找针对的是一个有序的数据集合,查找思想有点类似分治思想。每次都通过跟区间的中间元素对比,将待查找的区间缩小为之前的一半,直到找到要查找的元素,或者区间被缩小为 0。

时间复杂度O(nlogn)

代码Python

def bsearch(nums: List[int], target: int) -> int:"""Binary search of a target in a sorted arraywithout duplicates. If such a target does not exist,return -1, othewise, return its index."""low, high = 0, len(nums) - 1while low <= high:mid = low + (high - low) // 2if nums[mid] == target:return midelif nums[mid] < target:low = mid + 1else:high = mid - 1return -1

小结

这个挺好的,一直在排序算法那转了半天,终于到了下一环,感觉好多了。不过,这个查找算法一般都是排序好的,也就是经过排序算法排序好数据,然后用二分查找去找自己想要的数据。如果没有排序,给你一堆乱序数据,还是要先去排序,然后再去查找。这也是很多算法都先讲排序,后讲查找的原因(纯属猜测,如有雷同,请手下留情,忽略)。


http://www.ppmy.cn/devtools/30657.html

相关文章

Vue监测数组改变的原理

Vue监测数组改变的原理是通过重写数组的方法&#xff08;如push、pop、shift等&#xff09;来实现的。具体的实现步骤如下&#xff1a; 准备一个原始的数组&#xff0c;用于存储数据。 使用Object.defineProperty方法&#xff0c;给数组对象添加一个名为__ob__的属性&#xff…

[C++][数据结构]二叉搜索树:介绍和实现

二叉搜索树 概念 二叉搜索树又称二叉排序树&#xff0c;它是一棵空树&#xff0c;或者是具有以下性质的二叉树: 若它的左子树不为空&#xff0c;则左子树上所有节点的值都小于根节点的值若它的右子树不为空&#xff0c;则右子树上所有节点的值都大于根节点的值它的左右子树也…

笔记-用Python脚本启停JAR程序

用Python脚本启停JAR程序&#xff0c;需要用到python中的以下内置模块 subprocess 是 Python 的一个标准库模块&#xff0c;用于在新进程中执行子命令&#xff0c;获取子进程的输入/输出/错误以及返回码等os 是 Python 的一个标准库模块&#xff0c;它提供了与操作系统交互的功…

设计模式: 模板模式

目录 一&#xff0c;模板模式 二&#xff0c;特点 三&#xff0c;组成部分 四&#xff0c;实现步骤 五&#xff0c;案例 一&#xff0c;模板模式 模板模式&#xff08;Template Pattern&#xff09;是一种行为型设计模式&#xff0c;它在超类中定义了一个算法的骨架&#…

C++基础—模版

C模板是C语言中实现泛型编程的核心机制&#xff0c;它允许程序员定义通用的代码框架&#xff0c;这些框架在编译时可以根据提供的具体类型参数生成相应的特定类型实例。 泛型编程的特点代码复用和安全性! 模板主要分为两大类&#xff1a;函数模板和类模板。 函数模板 基本语…

SpringBoot-@Transactional注解失效

Transactional注解失效 Transactional失效场景 以下是一些常见导致Transactional注解失效的场景&#xff0c;配合相应的Java代码演示&#xff1a; 1、方法修饰符非公开&#xff08;非public&#xff09; Transactional注解失效的原因在于Spring事务管理器如何实现对事务的代…

springboot2.6.7集成springfox3.0.0

springboot2.6.7集成springfox3.0.0 1. pom配置2. 增加swagger自动配置类3. 配置修改4. 自动配置类增加以下内容参考 1. pom配置 <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger-ui --> <dependency><groupId>io.springfox</g…

机器学习入门之非监督学习和半监督学习

文章目录 非监督学习半监督学习机器学习的核心价值 非监督学习 与监督学习相反&#xff0c;非监督学习的训练数据集是完全没有标签的数据&#xff0c;他本质上所做的工作都是聚类的 给定数据之后&#xff0c;聚类能从中学习到什么&#xff0c;就完全取决于数据本身的特性的&a…