算法===二分查找

文章目录

概要

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

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

定义

二分的定义,来学习学习

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

时间复杂度O(nlogn)

代码Python

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

小结

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

相关推荐
报错小能手6 分钟前
C++笔记(面向对象)静态联编和动态联编
开发语言·c++·算法
WBluuue13 分钟前
AtCoder Beginner Contest 430(ABCDEF)
c++·算法
小肖爱笑不爱笑15 分钟前
2025/11/5 IO流(字节流、字符流、字节缓冲流、字符缓冲流) 计算机存储规则(ASCII、GBK、Unicode)
java·开发语言·算法
熬了夜的程序员31 分钟前
【LeetCode】99. 恢复二叉搜索树
算法·leetcode·职场和发展
Kent_J_Truman36 分钟前
LeetCode Hot100 自用
算法·leetcode·职场和发展
还是码字踏实36 分钟前
算法题种类与解题思路全面指南:基于LeetCode Hot 100与牛客Top 101
算法·leetcode
Victory_orsh2 小时前
“自然搞懂”深度学习(基于Pytorch架构)——010203
人工智能·pytorch·python·深度学习·神经网络·算法·机器学习
CoovallyAIHub2 小时前
突破360°跟踪极限!OmniTrack++:全景MOT新范式,HOTA指标狂飙43%
深度学习·算法·计算机视觉
得物技术2 小时前
得物管理类目配置线上化:从业务痛点到技术实现
后端·算法·数据分析
CoovallyAIHub3 小时前
首个大规模、跨模态医学影像编辑数据集,Med-Banana-50K数据集专为医学AI打造(附数据集地址)
深度学习·算法·计算机视觉