牛客小白月赛28 E 会当临绝顶,一览众山小

会当凌绝顶,一览众山小

https://ac.nowcoder.com/acm/contest/7412/E

题目可以转化成
1) 找某个坐标左边第一个比他大的数。
2) 找某个坐标右边最小的数。

这两个操作分别可以用两颗线段树维护。

1)中维护区间max,如果右区间最大值比要查询的值大,则递归右区间,否则递归左区间。
2)中维护区间min,如果据区间最小值比右区间最小值小,递归左区间,否则递归右区间。

复杂度O(nlogn)

#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;

#define lson rt * 2
#define rson rt * 2 + 1
#define MP make_pair

const int N = 4e5 + 100;

namespace Ma {
    int tree[N * 4];

    void insert(int id, int x, int l, int r, int rt) {
        if (l == r) {
            tree[rt] = x;
            return;
        }
        int m = (l + r) / 2;
        if (id <= m) insert(id, x, l, m, lson);
        else insert(id, x, m + 1, r, rson);
        tree[rt] = max(tree[lson], tree[rson]);
    }

    int query(int ql, int qr, int x, int l, int r, int rt) {
        if (tree[rt] <= x) return 0;
        if (l == r) return l;
        int m = (l + r) / 2;
        if (qr <= m) return query(ql, qr, x, l, m, lson);
        else {
            int t = query(m + 1, qr, x, m + 1, r, rson);
            if (t) return t;
            return query(ql, m, x, l, m, lson);
        }
    }

    int query2(int ql, int qr, int l, int r, int rt) {
        if (ql == l && qr == r) return tree[rt];
        int m = (l + r) / 2;
        if (qr <= m) return query2(ql, qr, l, m, lson);
        else if (m < ql) return query2(ql, qr, m + 1, r, rson);
        return max(query2(ql, m, l, m, lson), query2(m + 1, qr, m + 1, r, rson));
    }
}

int n;
int h[N], xx[N], rev[N];

namespace Mi {
    int tree[N * 4];

    void insert(int id, int x, int l, int r, int rt) {
        if (l == r) {
            tree[rt] = x;
            return;
        }
        int m = (l + r) / 2;
        if (id <= m) insert(id, x, l, m, lson);
        else insert(id, x, m + 1, r, rson);
        tree[rt] = min(tree[lson], tree[rson]);
    }

    int query(int ql, int qr, int l, int r, int rt) {
        if (l == r) return l;
        int m = (l + r) / 2;
        if (m < ql) return query(ql, qr, m + 1, r, rson);
        else {
            int t = 0;
            if (tree[lson] <= tree[rson]) t = query(ql, m, l, m, lson);
            if (t && h[rev[t]] <= tree[rson]) return t;
            return query(m + 1, qr, m + 1, r, rson);
        }
    }
}

int tp, has[N], ha[N];

void change(int i, int x) {
    h[i] = x;
    Ma::insert(xx[i], h[i], 1, n, 1);
    Mi::insert(xx[i], h[i], 1, n, 1);
}


int main() {
    //freopen("0.txt", "r", stdin);
    scanf("%d", &n);
    for (int i = 1; i <= n; i++) {
        scanf("%d%d", xx + i, h + i);
        has[i] = h[i];
        ha[i] = xx[i];
    }
    sort(has + 1, has + n + 1);
    tp = unique(has + 1, has + n + 1) - has;
    for (int i = 1; i <= n; i++) h[i] = lower_bound(has + 1, has + tp, h[i]) - has;
    sort(ha + 1, ha + n + 1);
    for (int i = 1; i <= n; i++) xx[i] = lower_bound(ha + 1, ha + n + 1, xx[i]) - ha, rev[xx[i]] = i;
    for (int i = 1; i <= n; i++) change(i, h[i]);
    for (int i = 1; i <= n; i++) {
        int t = Ma::query(1, xx[i], h[i], 1, n, 1);
        if (t) change(rev[t], h[i]);
        if (xx[i] + 1 <= n && Ma::query2(xx[i] + 1, n, 1, n, 1) <= h[i]) {
            t = Mi::query(xx[i] + 1, n, 1, n, 1);
            change(rev[t], h[i]);
        }
    }
    for (int i = 1; i <= n; i++) printf("%d%c", has[h[i]], i == n ? '\n' : ' ');
    return 0;
}
全部评论

相关推荐

02-28 01:18
已编辑
南昌大学 后端工程师
黑皮白袜臭脚体育生:把开源经历放个人项目上边应该更好,就像大部分人都把实习经历放个人项目上边
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
正在热议
更多
# 一张图晒出你司的标语 #
4378次浏览 77人参与
# AI面会问哪些问题? #
28219次浏览 565人参与
# 开放七大实习专项,百度暑期实习值得冲吗 #
15381次浏览 223人参与
# 你的实习产出是真实的还是包装的? #
20395次浏览 343人参与
# 找AI工作可以去哪些公司? #
9351次浏览 247人参与
# 春招至今,你的战绩如何? #
66175次浏览 584人参与
# 米连集团26产品管培生项目 #
13397次浏览 285人参与
# 从事AI岗需要掌握哪些技术栈? #
9172次浏览 321人参与
# 中国电信笔试 #
32068次浏览 295人参与
# 你做过最难的笔试是哪家公司 #
34279次浏览 245人参与
# 投递几十家公司,到现在0offer,大家都一样吗 #
340960次浏览 2175人参与
# 哪些公司真双非友好? #
69694次浏览 289人参与
# 阿里笔试 #
179001次浏览 1318人参与
# 机械人避雷的岗位/公司 #
62708次浏览 393人参与
# 小马智行求职进展汇总 #
25139次浏览 80人参与
# 第一份工作一定要去大厂吗 #
14875次浏览 122人参与
# 金三银四,你的春招进行到哪个阶段了? #
22226次浏览 284人参与
# 担心入职之后被发现很菜怎么办 #
291382次浏览 1210人参与
# 为了减少AI幻觉,你注入过哪些设定? #
26274次浏览 310人参与
# 应届生第一份工资要多少合适 #
20694次浏览 86人参与
# HR最不可信的一句话是__ #
6346次浏览 114人参与
# 沪漂/北漂你觉得哪个更苦? #
10029次浏览 194人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务