lower_bound()和upper_bound()
(转 lower_bound 的使用 - EdisonBa - 博客园 (cnblogs.com))
#include<algorithm>
lower_bound()适用于单调递增数组 upper_bound()适用于单调递减数组
lower_bound()与upper_bound()一个用法
单纯数组
//查找范围:[ begin , end ) ,左闭右开区间。 *lower_bound(begin, end, num); //返回第一个 >= num 的数的数值 lower_bound(begin, end, num) - begin; // 返回下标 实际操作: int a[100] = {0, 1, 3, 5, 7, 9, 10}; // 下标:0 1 2 3 4 5 6 int main() { int x = lower_bound(a + 1, a + 6 + 1, 6) - a; //输出下标 int y = *lower_bound(a + 1, a + 6 + 1, 6); //输出值 printf("%d %d", x, y); return 0; } 输出结果:4 7
结构体
struct node //开结构体 { int a, id; //定义结构体内的两个变量 node() {} node(int x, int y) : a(x), id(y) {} bool operator<(const node t) const //重载 { return a < t.a; } } t[1001]; bool cmp(node x, node y) //快排 cmp 比较函数 { if (x.a < y.a) return 1; //结构体内按 a 由小到大排序。 return 0; } int main() { int n = read(); //数列中数的个数 for (int i = 1; i <= n; ++i) { t[i].a = read(); //读入数列 t[i].id = i; } sort(t + 1, t + n + 1, cmp); //按小到大排序 int x, xiabiao, ans; x = read(); //需要查找的数字 xiabiao = lower_bound(t + 1, t + n + 1, node(x, 0)) - t; //这样求下标 ans = (*lower_bound(t + 1, t + n + 1, node(x, 0))).a; //这样求值 printf("%d %d\n", xiabiao, ans); return 0; } 输入: 5 20 40 30 10 50 35 输出: 4 40
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步