原题链接 G - Range Sort Query

思路:

\(x\)是固定的,所以考虑将排序维护成0 1串,为\(p_i < x\)为\(0\),那么\(p_i \geq x\)为\(1\),那么这样就可以用线段树维护了,我们可以维护每个区间1的个数,设为\(cnt\),对于升序来说,设我们需要更新的这个区间\([l, r]\),那么现在查询后,更新新的区间就是\([r - cnt + 1, 1]\)为\(1\),更新\([l, r - cnt]\)为\(0\),所以维护两颗线段树,一颗是\(p_i \geq x\),另一颗是\(p_i \geq x + 1\),那么最后可以从\(1 - N\)遍历查询,若\(t1.query(1, i, i)\)与\(t2.query(1, i, i)\)两者不相等,说明这就是我们要找的那个位置。

一开始把懒标记初值设成了0,怎么也不对,后来对拍了半天才发现有是因为懒标记有0 1值,那初值肯定不能是0 1,所以改成-1,就对了。

#include <bits/stdc++.h>

using namespace std;

const int N = 2E5 + 10;
int w[N], n, q, x; struct SegMentTree {
struct node {
int l, r;
int val, tag;
}tr[N * 4]; void pushup(int u) {
tr[u].val = tr[u << 1].val + tr[u << 1 | 1].val;
} void pushdown(int u) {
auto &root = tr[u], &left = tr[u << 1], &right = tr[u << 1 | 1];
if (~root.tag) {
left.tag = root.tag;
left.val = root.tag * (left.r - left.l + 1); right.tag = root.tag;
right.val = root.tag * (right.r - right.l + 1);
root.tag = -1;
}
} void build(int u, int l, int r, int x) {
tr[u] = {l, r};
tr[u].tag = -1;
if (l == r) {
tr[u].val = (w[l] >= x);
//tr[u].tag = 0;
return;
}
int mid = l + r >> 1;
build(u << 1, l, mid, x), build(u << 1 | 1, mid + 1, r, x);
pushup(u);
} void modify(int u, int l, int r, int x) {
if (l <= tr[u].l && tr[u].r <= r) {
tr[u].tag = x;
tr[u].val = x * (tr[u].r - tr[u].l + 1);
return;
} pushdown(u);
int mid = tr[u].l + tr[u].r >> 1;
if (l <= mid) modify(u << 1, l, r, x);
if (r > mid) modify(u << 1 | 1, l, r, x);
pushup(u);
} int query(int u, int l, int r) {
if (l <= tr[u].l && tr[u].r <= r) {
return tr[u].val;
} pushdown(u);
int mid = tr[u].l + tr[u].r >> 1;
int res = 0;
if (l <= mid) res += query(u << 1, l, r);
if (r > mid) res += query(u << 1 | 1, l, r);
return res;
}
}t1, t2; int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
//freopen("D:\\cpeditor\\competition\\Atcoder\\abc237\\data.txt", "r", stdin);
//freopen("D:\\cpeditor\\competition\\Atcoder\\abc237\\myans.txt", "w", stdout);
cin >> n >> q >> x;
for (int i = 1; i <= n; i++) cin >> w[i];
t1.build(1, 1, n, x);
t2.build(1, 1, n, x + 1);
while (q--) {
int op, l, r;
cin >> op >> l >> r;
int cnt1 = t1.query(1, l, r), cnt2 = t2.query(1, l, r);
int len = r - l + 1;
if (op == 1) { //asc
if (cnt1 && cnt1 != len) {
t1.modify(1, l, r - cnt1, 0); t1.modify(1, r - cnt1 + 1, r, 1);
}
if (cnt2 && cnt2 != len) {
t2.modify(1, l, r - cnt2, 0); t2.modify(1, r - cnt2 + 1, r, 1);
}
} else {
if (cnt1 && cnt1 != len) {
t1.modify(1, l, l + cnt1 - 1, 1); t1.modify(1, l + cnt1, r, 0);
}
if (cnt2 && cnt2 != len) {
t2.modify(1, l, l + cnt2 - 1, 1); t2.modify(1, l + cnt2, r, 0);
}
}
} // cout << "test" << endl;
for(int i = 1; i <= n; i++) {
//cout << t1.query(1, i, i) << " " << t2.query(1, i, i) << endl;
if(t1.query(1, i, i) != t2.query(1, i, i)) {
cout << i << "\n";
}
} //fclose(stdin);
//fclose(stdout); return 0;
}

AtCoder Beginner Contest 237 G - Range Sort Query的更多相关文章

  1. AtCoder Beginner Contest 272 - G - Yet Another mod M

    随机 + 数论 题意 Submission #35524126 - AtCoder Beginner Contest 272 给一个长度为 \(n\;(1<=n<=5000)\) 的数组 ...

  2. AtCoder Beginner Contest 260 G // imos(累积和算法)

    题目传送门:G - Scalene Triangle Area (atcoder.jp) 题意: 给定大小为N*N的OX矩阵,若矩阵的(s,t)处为O,其覆盖范围为:满足以下条件的所有位置(i,j) ...

  3. AtCoder Beginner Contest 282 G - Similar Permutation

    套路题 题意 求有多少个 \(1\) 到 \(n\) 的排列满足恰有 \(k\) 对在排列中相邻的数满足前小于后 \(2 \leq n \leq 500, 0 \leq k \leq (n - 1)\ ...

  4. AtCoder Beginner Contest 242 题解

    目录 C - 1111gal password D - ABC Transform E - (∀x∀) F - Black and White Rooks G - Range Pairing Quer ...

  5. AtCoder Beginner Contest 136

    AtCoder Beginner Contest 136 题目链接 A - +-x 直接取\(max\)即可. Code #include <bits/stdc++.h> using na ...

  6. AtCoder Beginner Contest 154 题解

    人生第一场 AtCoder,纪念一下 话说年后的 AtCoder 比赛怎么这么少啊(大雾 AtCoder Beginner Contest 154 题解 A - Remaining Balls We ...

  7. AtCoder Beginner Contest 184 题解

    AtCoder Beginner Contest 184 题解 目录 AtCoder Beginner Contest 184 题解 A - Determinant B - Quizzes C - S ...

  8. AtCoder Beginner Contest 173 题解

    AtCoder Beginner Contest 173 题解 目录 AtCoder Beginner Contest 173 题解 A - Payment B - Judge Status Summ ...

  9. AtCoder Beginner Contest 285 解题报告

    AtCoder Beginner Contest 285 解题报告 \(\text{DaiRuiChen007}\) Contest Link A. Edge Checker 2 假设 \(a\ge ...

  10. AtCoder Beginner Contest 100 2018/06/16

    A - Happy Birthday! Time limit : 2sec / Memory limit : 1000MB Score: 100 points Problem Statement E8 ...

随机推荐

  1. 【go语言】2.1.3 函数的定义和使用

    在 Go 语言中,函数是一种代码抽象和复用的方式.函数可以接受参数,执行特定的操作,并返回结果. 函数的定义 函数的定义以 func 关键字开始,后面跟着函数名.参数列表.返回值列表(可选)以及函数体 ...

  2. Linux 下的 OpenGL 之路(九):天空盒、反射和折射

    前言 搞定了天空盒,才算是真正完成了场景的搭建,以后再要进行什么样的图形学测试,都可以在这个场景下进行.比如后面的反射.折射就是这样的例子. 写完这篇,我决定暂时结束这个系列.主要是因为我太懒了,居然 ...

  3. SpringBoot 启动流程分析(寻找扩展点)

    1.SpringBoot maven 依赖版本 <?xml version="1.0" encoding="UTF-8"?> <project ...

  4. Vue中 router与route的区别

    $route对象 该对象表示当前的路由信息,包含当前URL解析得到的信息.包含当前的路径,参数,query对象等.其常用方法如下所示: $route.path 字符串,对应当前路由的路径,总是解析为绝 ...

  5. 【技术积累】Linux中的命令行【理论篇】【三】

    apt-get命令 命令介绍 Debian Linux发行版中的APT软件包管理工具,apt-get命令 是Debian Linux发行版中的APT软件包管理工具.所有基于Debian的发行都使用这个 ...

  6. redis数据持久化之RDB和AOF

    前言 redis虽然是内存缓存程序,但是可以将内存中的数据保存到硬盘上,从而实现数据保存.目前有两种redis数据持久化方式,分别是RDB和AOF. RDB模式 RDB之简介 RDB(redis da ...

  7. 操作过滤器—MVC中使用操作过滤器实现JWT权限认证

    前言 上一篇文章分享了授权过滤器实现JWT进行鉴权,文章链接:授权过滤器-MVC中使用授权过滤器实现JWT权限认证,接下来将用操作过滤器实现昨天的JWT鉴权. 一.什么是操作过滤器? ​ 与授权过滤器 ...

  8. Elasticsearch之常用术语

    一. 数据库和ES简单类比 关系型数据库 表(Table) 行(Row) 列(Cloumn) Schema SQL Elasticsearch 索引(Index) 文档(Document) 字段(Fi ...

  9. 关于TCP 四次挥手过程中的reset包问题

    数据包过程 TCP状态机转换过程 客户端在接受到第32个数据包之后,应该发送1个对FIN的ACK数据包,然而客户端缺直接连续发送了3个Rest数据包36~38,客户端并未进入time wait阶段,直 ...

  10. 2017-A1

    #include <iostream> #include <string> using namespace std; int main(){ string s; cin> ...