求区间内第一个大于等于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的数的下标的主要内容,如果未能解决你的问题,请参考以下文章