lower_bound()以及upper_bound()

lower_bound():

lower_bound()的返回值是第一个大于等于 target 的值的地址,用这个地址减去first,得到的就是第一个大于等于target的值的下标。

在数组中:

int pos=lower_bound(a,a+n,target)-a;\\n为数组长度

vector容器中:

int pos=lower_bound(a.begin(),a.end(),target)-a.begin();

upper_bound():

从小到大 的排好序的数组中,在数组的 [begin, end) 区间中二分查找第一个大于value的数,找到返回该数字的地址,没找到则返回end。用这个地址减去first,得到的就是第一个大于等于target的值的下标。

在数组中:

int pos=upper_bound(a,a+n,target)-a;\\n为数组长度

vector容器中:

int pos=upper_bound(a.begin(),a.end(),target)-a.begin();

相关推荐
小白程序员成长日记15 分钟前
2025.11.16 力扣每日一题
算法
Kuo-Teng1 小时前
LeetCode 118: Pascal‘s Triangle
java·算法·leetcode·职场和发展·动态规划
Greedy Alg1 小时前
LeetCode 32. 最长有效括号(困难)
算法
ShineWinsu1 小时前
对于数据结构:链式二叉树的超详细保姆级解析—中
数据结构·c++·算法·面试·二叉树·校招·递归
野蛮人6号2 小时前
力扣热题100道之207课程表
算法·leetcode·职场和发展
这周也會开心2 小时前
Map的遍历方式
数据结构·算法
无敌最俊朗@2 小时前
C++ 值类别与对象模型面试题(12)
算法
代码不停3 小时前
Java模拟算法题目练习
java·开发语言·算法
前端小L3 小时前
图论专题(二):“关系”的焦点——一眼找出「星型图的中心节点」
数据结构·算法·深度优先·图论·宽度优先
资深web全栈开发3 小时前
贪心算法套路解析
算法·贪心算法·golang