论为何没有k分

拿二分查找举例子

查找一个单调序列的第一个>x的位置

这里不用k分的原因是

k分的严格复杂度实际上是O(klogkn)

因为你在k分的时候

你需要花费O(k)的时间判断在这k个分支中应该选择哪一个

(从[l1,r1],[l2,r2],......[lk,rk]中选一个)

又因为klogkn=kln(n)ln(k)=ln(n)kln(k)

这个关于k的函数在(1,e)单调递减,(e,+inf)单调递增

因此k的最优取值是2或3

2/ln2=2.88539

3/ln3=2.73071
因此理论上来说三分是比二分优秀一点点的

但是差距基本可以忽略,而且二分代码远比三分简单

所以通常使用二分

posted @   Creed-qwq  阅读(786)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示