【算法】二分查找时间复杂度分析

时间复杂度分析Tworst(N)

显然,每次迭代在循环内的所有工作花费为O(1)。

二分查找每次排除掉一半的不适合值,所以对于N个元素的情况:

一次二分剩下:N/2

两次二分剩下:N/2/2 = N/4

...

M次二分剩下:N/(2M)

在最坏情况下是在排除到只剩下最后一个值之后得到结果,即

N/(2M) = 1``(此时剩下的一个元素必定是要查找的元素)```

所以由上式可得 :

2M = N

M = log2N

相关推荐
YUDAMENGNIUBI2 小时前
day20_逻辑回归
算法·机器学习·逻辑回归
澈2076 小时前
C++并查集:高效解决连通性问题
java·c++·算法
旖-旎7 小时前
深搜练习(单词搜索)(12)
c++·算法·深度优先·力扣
企客宝CRM8 小时前
2026年中小企业CRM选型指南:企客宝CRM处于什么位置?
android·算法·企业微信·rxjava·crm
橙淮8 小时前
二叉树核心概念与Java实现详解
数据结构·算法
米罗篮8 小时前
DSU并查集 & 拓展欧几里得-逆元
c++·经验分享·笔记·算法·青少年编程
橙淮8 小时前
双指针法:高效算法解题的利器
算法
初心未改HD9 小时前
深度学习之MLP与反向传播算法详解
人工智能·深度学习·算法
刀法如飞9 小时前
【Go 字符串查找的 20 种实现方式,用不同思路解决问题】
人工智能·算法·go