\(\text{Problem}\)

动态区间第 \(k\) 小

Dynamic Rankings

\(\text{Analysis}\)

整体二分

原本一个询问可二分,但多个询问效率太低

考虑离线,把修改和询问扔到一起

二分答案,运用树状数组之类的东西处理完修改操作

依次检查询问,划分左右,初步确定每个询问的答案值域,修改操作相应地划分到有必要的一边(左右)

\(\text{Code}\)

#include<cstdio>
using namespace std; const int N = 1e5 + 5;
int n, m, cnt, a[N], ans[N], T[N]; struct node{
int ty, l, r, k, id;
}q[N * 3], q1[N * 3], q2[N * 3]; inline void read(int &x)
{
x = 0; char ch = getchar();
while (ch < '0' || ch > '9') ch = getchar();
while (ch >= '0' && ch <= '9') x = x * 10 + ch - '0', ch = getchar();
} inline int lowbit(int x){return x & (-x);}
inline void add(int x, int v){for(; x <= n; x += lowbit(x)) T[x] += v;}
inline int query(int x)
{
int ret = 0;
for(; x; x -= lowbit(x)) ret += T[x];
return ret;
} void solve(int l, int r, int ql, int qr)
{
if (ql > qr) return;
if (l == r)
{
for(int i = ql; i <= qr; i++) ans[q[i].id] = l;
return;
}
int ct1 = 0, ct2 = 0, mid = (l + r) >> 1;
for(int i = ql; i <= qr; i++)
{
if (q[i].ty == 1)
{
if (q[i].l <= mid) add(q[i].r, q[i].k), q1[++ct1] = q[i];
else q2[++ct2] = q[i];
}
else{
int sum = query(q[i].r) - query(q[i].l - 1);
if (sum >= q[i].k) q1[++ct1] = q[i];
else q[i].k -= sum, q2[++ct2] = q[i];
}
}
for(int i = 1; i <= ct1; i++)
if (q1[i].ty == 1) add(q1[i].r, -q1[i].k);
for(int i = 1; i <= ct1; i++) q[ql + i - 1] = q1[i];
for(int i = 1; i <= ct2; i++) q[ql + ct1 + i - 1] = q2[i];
solve(l, mid, ql, ql + ct1 - 1);
solve(mid + 1, r, ql + ct1, qr);
} int main()
{
read(n), read(m);
for(int i = 1; i <= n; i++) read(a[i]), q[++cnt] = node{1, a[i], i, 1};
char op[3];
for(int i = 1, l, r, k; i <= m; i++)
{
scanf("%s", op), read(l), read(r);
if (op[0] == 'C') q[++cnt] = node{1, a[l], l, -1}, q[++cnt] = node{1, a[l] = r, l, 1};
else read(k), q[++cnt] = node{2, l, r, k, i};
}
solve(0, 1e9, 1, cnt);
for(int i = 1; i <= m; i++)
if (ans[i]) printf("%d\n", ans[i]);
}

当然可以树状数组套权值线段树

\(\text{Code}\)

#include <cstdio>
#include <algorithm>
#include <iostream>
#define re register
using namespace std; const int N = 1e5 + 5;
int n, m, len, a[N], b[N * 2], ct1, ct2, tmp1[50], tmp2[50];
struct que{int o, l, r, k;}q[N]; inline void read(int &x)
{
x = 0; char ch = getchar();
while (!isdigit(ch)) ch = getchar();
while (isdigit(ch)) x = (x<<3)+(x<<1)+(ch^48), ch = getchar();
} int size, rt[N], sum[N * 400], ls[N * 400], rs[N * 400];
void modify(int &p, int l, int r, int x, int v)
{
if (!p) p = ++size;
sum[p] += v;
if (l == r) return;
int mid = (l + r) >> 1;
if (x <= mid) modify(ls[p], l, mid, x, v);
else modify(rs[p], mid + 1, r, x, v);
}
int query(int l, int r, int k)
{
if (l == r) return l;
int s = 0, mid = (l + r) >> 1;
for(re int i = 1; i <= ct1; i++) s += sum[ls[tmp1[i]]];
for(re int i = 1; i <= ct2; i++) s -= sum[ls[tmp2[i]]];
if (k <= s)
{
for(re int i = 1; i <= ct1; i++) tmp1[i] = ls[tmp1[i]];
for(re int i = 1; i <= ct2; i++) tmp2[i] = ls[tmp2[i]];
return query(l, mid, k);
}
else{
for(re int i = 1; i <= ct1; i++) tmp1[i] = rs[tmp1[i]];
for(re int i = 1; i <= ct2; i++) tmp2[i] = rs[tmp2[i]];
return query(mid + 1, r, k - s);
}
} inline int lowbit(int x){return x & (-x);}
inline void Modify(int x, int val, int v)
{
val = lower_bound(b + 1, b + len + 1, val) - b;
for(; x <= n; x += lowbit(x)) modify(rt[x], 1, len, val, v);
}
inline int Query(int l, int r, int k)
{
ct1 = ct2 = 0;
for(; r; r -= lowbit(r)) tmp1[++ct1] = rt[r];
for(l = l - 1; l; l -= lowbit(l)) tmp2[++ct2] = rt[l];
return b[query(1, len, k)];
} int main()
{
read(n), read(m);
for(re int i = 1; i <= n; i++) read(a[i]), b[++len] = a[i];
int l, r, k; char op[3];
for(re int i = 1; i <= m; i++)
{
scanf("%s", op), read(l), read(r);
if (op[0] == 'Q') read(k), q[i] = que{1, l, r, k};
else q[i] = que{0, l, r}, b[++len] = r;
}
sort(b + 1, b + len + 1);
len = unique(b + 1, b + len + 1) - b - 1;
for(re int i = 1; i <= n; i++) Modify(i, a[i], 1);
for(re int i = 1; i <= m; i++)
if (q[i].o == 1) printf("%d\n", Query(q[i].l, q[i].r, q[i].k));
else Modify(q[i].l, a[q[i].l], -1), Modify(q[i].l, a[q[i].l] = q[i].r, 1);
}

LG P2617 Dynamic Rankings的更多相关文章

  1. P2617 Dynamic Rankings(树状数组套主席树)

    P2617 Dynamic Rankings 单点修改,区间查询第k大 当然是无脑树套树了~ 树状数组套主席树就好辣 #include<iostream> #include<cstd ...

  2. 2018.07.01洛谷P2617 Dynamic Rankings(带修主席树)

    P2617 Dynamic Rankings 题目描述 给定一个含有n个数的序列a[1],a[2],a[3]--a[n],程序必须回答这样的询问:对于给定的i,j,k,在a[i],a[i+1],a[i ...

  3. 洛谷P2617 Dynamic Rankings (主席树)

    洛谷P2617 Dynamic Rankings 题目描述 给定一个含有n个数的序列a[1],a[2],a[3]--a[n],程序必须回答这样的询问:对于给定的i,j,k,在a[i],a[i+1],a ...

  4. 洛谷 P2617 Dynamic Rankings 解题报告

    P2617 Dynamic Rankings 题目描述 给定一个含有\(n\)个数的序列\(a[1],a[2],a[3],\dots,a[n]\),程序必须回答这样的询问:对于给定的\(i,j,k\) ...

  5. 【学习笔鸡】整体二分(P2617 Dynamic Rankings)

    [学习笔鸡]整体二分(P2617 Dynamic Rankings) 可以解决一些需要树套树才能解决的问题,但要求询问可以离线. 首先要找到一个具有可二分性的东西,比如区间\(k\)大,就很具有二分性 ...

  6. luogu P2617 Dynamic Rankings && bzoj 1901 (带修改区间第k大)

    链接:https://www.luogu.org/problemnew/show/P2617 思路: 如果直接在主席树上修改的话,每次修改都会对后面所有的树造成影响,一次修改的复杂度就会变成 : n* ...

  7. P2617 Dynamic Rankings(待修改区间第k大)

    题目链接:https://www.luogu.org/problemnew/show/P2617 题目: 题目描述 给定一个含有n个数的序列a[1],a[2],a[3]……a[n],程序必须回答这样的 ...

  8. 洛谷P2617 Dynamic Rankings

    带修主席树模板题 主席树的单点修改就是把前缀和(大概)的形式改成用树状数组维护,每个树状数组的元素都套了一个主席树(相当于每个数组的元素root[i]都是主席树,且这个主席树维护了(i - lowbi ...

  9. Luogu P2617 Dynamic Rankings

    带修主席树的模板,因为状态不好所以敲了很长时间,不过写完感觉能更好地理解主席树了. 核心其实就是树状数组套主席树,维护方法不再是以前的那种一步一修改,而是对于树状数组上的每一个点建立一棵权值线段树,然 ...

  10. P2617 Dynamic Rankings(带修主席树)

    所谓带修主席树,就是用树状数组的方法维护主席树的前缀和 思路 带修主席树的板子 注意数据范围显然要离散化即可 代码 #include <cstdio> #include <cstri ...

随机推荐

  1. BFS和DFS学习笔记

    1 算法介绍 1.1 BFS Breadth First Search(广度优先搜索),将相邻的节点一层层查找,找到最多的 以上图为例,首先确定一个根节点,然后依次在剩下的节点中找已找出的节点的相邻节 ...

  2. Referenced file contains errors (http://mybatis.org/dtd/mybatis-3-config.dtd). For more information, right click on the message in the Problems View and select "Show Details..."

    mybatis配置文件报错Referenced file contains errors mybatis的配置文件报错 The errors below were detected when vali ...

  3. CSS伪类使用详解

    基本描述 CSS伪类是很常用的功能,主要应用于选择器的关键字,用来改变被选择元素的特殊状态下的样式. 伪类类似于普通CSS类的用法,是对CSS选择器的一种扩展,增强选择器的功能. 目前可用的伪类有大概 ...

  4. Entity Framework Core 7中高效地进行批量数据插入

    因为之前的版本中,EF Core无法实现高效地批量插入.修改.删除数据,所以我开发了Zack.EFCore.Batch这个开源项目,比较受大家的欢迎,获得了400多个star. 从.NET 7开始,微 ...

  5. vscode+springboot+gradle

    vscode+springboot+gradle 项目搭建 demo 目标:项目中抛弃所有xml格式文件 啰嗦: 一直在用maven作为项目的依赖包管理,最近看到基于Java17 的 Spring f ...

  6. APACHE正向代理配置

    Apache快速安装和反向代理配置:https://www.cnblogs.com/brad93/p/16718104.html Apache正向代理配置参考教程:https://www.cnblog ...

  7. 【每日一题】【归并排序/堆排序&虚拟头结点】148. 排序链表-211220/220217【出栈时不断容易产生环状链表!】

    给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表 . 进阶: 你可以在 O(n log n) 时间复杂度和常数级空间复杂度下,对链表进行排序吗? 方法1:归并排序+使用辅助函数 ...

  8. Elasticsearch模糊查询、多字段in查询、时间范围查询,DSL和java API两种方式

    Elasticsearch模糊查询.多字段in查询.时间范围查询,DSL和java API两种方式 项目场景: Elasticsearch模糊查询某字段.多字段in查询.时间范围查询,通过DSL和ja ...

  9. 五年经验的前端社招被问:CPU 和 GPU 到底有啥区别?

    首先来看 CPU 和 GPU 的百科解释: CPU(Central ProcessingUnit,中央处理器):功能主要是解释计算机指令以及处理计算机软件中的数据 GPU(Graphics Proce ...

  10. redis集合 实现 队列

    先说一下需求:用队列解决 流量削峰,主要应用场景:商城秒杀功能. 以下是业务流程图可以参考一下: 然后本地实现思路 截图下单页面 每次购买数量会减少1,设置了1000个库存,用户id 是随机生成的. ...