算法札记:二分

二分的本质不是单调性

++二分的本质是序列二分后两段性质不同++

比如对于这个数列:4 3 2 1 5 5 9 8 7 6(5左边的数小于等于5,5右边的数大于等于5)

我要找5第一次出现的位置,一样的可以用二分

为什么

我只需要执行这个任务:将序列划成两段,左段都小于5,右段都大于等于5,取右端第一个点

每次二分,我只需要执行这个判断:当前数(amid)大于等于5 吗?如果是,那他和他右边的数一定满足大于等于5,此时我想要的肯定在l~mid,缩右边界r=mid,反之缩左边界l=mid+1

cpp 复制代码
while (l<r){
            int mid=l+r>>1;
            if (a[mid]>=k){
                r=mid;
            }else{
                l=mid+1;
            }
        }

若找5最后一次出现的位置,以此类推,懒得打字了

cpp 复制代码
        while (l<r){
            int mid=l+r+1>>1;//???
            if (a[mid]<=k){
                l=mid;
            }else{
                r=mid-1;
            }
        }

//???+1的原因:如果不加一,带数据1 2,我找2,直接死循环

相关推荐
TCW11211 小时前
AI底层系列:用C++实现线性代数的公式推导与算法设计-6.线性方程组的解集
c++·人工智能·算法
luoyayun3611 小时前
从零实现 EBU R128 LUFS 响度分析:K-weighting 滤波、双门限算法
算法·lufs响度分析
小糯米6011 小时前
JS 数组
数据结构·算法·排序算法
拳里剑气2 小时前
C++算法:链表
c++·算法·链表
凌波粒2 小时前
LeetCode--90.子集II(回溯算法)
数据结构·算法·leetcode
旖-旎2 小时前
《LeetCode 417 太平洋大西洋水流问题 FloodFill DFS 解法》
c++·算法·深度优先·力扣·floodfill
凌波粒2 小时前
LeetCode--46.全排列(回溯算法)
数据结构·算法·leetcode
2zcode2 小时前
项目文档:基于MATLAB语音信号变声算法设计与实现
算法·matlab·语音识别
指令集梦境2 小时前
图解:单调栈算法模板(Java语言)
java·开发语言·算法