求区间内第一个大于等于x的数的下标

Posted zxz666

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了求区间内第一个大于等于x的数的下标相关的知识,希望对你有一定的参考价值。

int tree[4*N];
void build(int o,int l,int r) 
    if(l==r) cin>>tree[o];return;
    build(ls,l,mid);
    build(rs,mid+1,r);
    tree[o] = max(tree[ls],tree[rs]);

int get(int o, int l, int r, int x) 
    if (l == r) return l;
    return tree[ls] > x ? get(ls, l, mid, x) : get(rs, mid+1, r, x);

int query(int o, int l, int r, int ql, int qr, int x)  //查询[ql,qr]内第一个大于x的数的位置
    if (qr < l || r < ql) return -1;
    if (ql <= l && r <= qr) return tree[o] > x ? get(o, l, r, x) : -1;
    int t = query(ls, l, mid, ql, qr, x);
    return t != -1 ? t : query(rs, mid+1, r, ql, qr, x);

 

以上是关于求区间内第一个大于等于x的数的下标的主要内容,如果未能解决你的问题,请参考以下文章

数位dp(二进制01问题)

Python求解答过程

HDU 6231 (二分+双指针)

BZOJ2653 middle

玲珑杯 1157 造物主的戒律

数位DP题集