upper_bound and lower_bound

#include <bits/stdc++.h>
using namespace std;

int main()
{
    int b[11] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
    int a[11] = {0, 1, 1, 1, 2, 2, 2, 2, 3, 3, 4};
    printf("%d\n", ((int)a - 7208600)/sizeof(int));
    ///upper_bound来说,返回的是被查序列中第一个大于查找值的指针,也就是返回指向被查值>查找值的最小指针
    printf("%d\n", ((int)upper_bound(a, a + 11, 2) - 7208600)/sizeof(int));
    ///lower_bound则是返回的是被查序列中第一个大于等于查找值的指针,也就是返回指向被查值>=查找值的最小指针。
    printf("%d\n", ((int)lower_bound(a, a + 11, 2) - 7208600)/sizeof(int));
    cout << upper_bound(a, a + 11, 2) - a << '\n';
    cout << lower_bound(a, a + 11, 2) - a << '\n';
    return 0;
}

全部评论

相关推荐

05-29 22:11
门头沟学院 Java
Elastic90:抛开学历造假不谈,这公司的招聘需求也挺怪的,Java开发还要求你有图文识别、移动端开发和c++的经验,有点逆天了。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务