题目链接

洛谷

bzoj

题解

整体二分

Code

#include<bits/stdc++.h>

#define LL long long
#define RG register using namespace std; inline int gi() {
RG int x = 0; RG char c = getchar(); bool f = 0;
while (c != '-' && (c < '0' || c > '9')) c = getchar();
if (c == '-') c = getchar(), f = 1;
while (c >= '0' && c <= '9') x = x*10+c-'0', c = getchar();
return f ? -x : x;
}
const int N = 50010;
int n, m; #define ls (rt<<1)
#define rs (rt<<1|1) LL t[N<<2], z[N<<2];
inline void pushdown(int rt, int l, int r) {
if (z[rt]) {
int mid = (l + r) >> 1;
t[ls] += (mid-l+1)*z[rt]; t[rs] += (r-mid)*z[rt];
z[ls] += z[rt]; z[rs] += z[rt];
z[rt] = 0;
}
return;
}
inline void update(int rt, int l, int r, int L, int R, int k) {
if (L <= l && r <= R) {
z[rt] += k;
t[rt] += k*(r-l+1);
return ;
}
int mid = (l + r) >> 1;
pushdown(rt, l, r);
if (L <= mid)
update(ls, l, mid, L, R, k);
if (R > mid)
update(rs, mid+1, r, L, R, k);
t[rt] = t[ls]+t[rs];
return ;
} inline LL query(int rt, int l, int r, int L, int R) {
if (L <= l && r <= R) return t[rt];
int mid = (l + r) >> 1;
LL s = 0;
pushdown(rt, l, r);
if (L <= mid)
s = query(ls, l, mid, L, R);
if (R > mid)
s += query(rs, mid+1, r, L, R);
t[rt] = t[ls]+t[rs];
return s;
}
struct Question {
int op, a, b, id;
LL c;
}q[N], lq[N], rq[N];
LL ans[N]; void div(int l, int r, int st, int ed) {
if (st > ed) return ;
if (l == r) {
for (int i = st; i <= ed; i++)
if (q[i].op == 2)
ans[q[i].id] = l;
return ;
}
int mid = (l + r) >> 1, lt = 0, rt = 0;
for (int i = st; i <= ed; i++) {
if (q[i].op == 1) {
if (q[i].c <= mid)
lq[++lt] = q[i];
else update(1, 1, n, q[i].a, q[i].b, 1), rq[++rt] = q[i];
}
else {
LL s = query(1, 1, n, q[i].a, q[i].b);
if (s >= q[i].c) rq[++rt] = q[i];
else q[i].c -= s, lq[++lt] = q[i];
}
}
for (int i = st; i <= ed; i++)
if (q[i].op == 1 && q[i].c > mid) update(1, 1, n, q[i].a, q[i].b, -1);
for (int i = 1; i <= lt; i++)
q[st+i-1] = lq[i];
for (int i = 1; i <= rt; i++)
q[st+lt+i-1] = rq[i];
div(l, mid, st, st+lt-1); div(mid+1, r, st+lt, ed);
return ;
} int main() {
n = gi(); m = gi();
int k = 0;
for (int i = 1; i <= m; i++) {
q[i].op = gi(), q[i].a = gi(), q[i].b = gi();
scanf("%lld", &q[i].c);
q[i].id = (q[i].op == 2) ? ++k : 0;
}
div(-n, n, 1, m);
for (int i = 1; i <= k; i++)
printf("%lld\n", ans[i]);
return 0;
}

洛谷 P3332 BZOJ 3110 [ZJOI2013]K大数查询的更多相关文章

  1. BZOJ 3110: [Zjoi2013]K大数查询 [树套树]

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6050  Solved: 2007[Submit][Sta ...

  2. 树套树专题——bzoj 3110: [Zjoi2013] K大数查询 &amp; 3236 [Ahoi2013] 作业 题解

    [原题1] 3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MB Submit: 978  Solved: 476 Descri ...

  3. bzoj 3110: [Zjoi2013]K大数查询 树状数组套线段树

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 1384  Solved: 629[Submit][Stat ...

  4. BZOJ 3110: [Zjoi2013]K大数查询( 树状数组套主席树 )

    BIT+(可持久化)权值线段树, 用到了BIT的差分技巧. 时间复杂度O(Nlog^2(N)) ---------------------------------------------------- ...

  5. BZOJ 3110([Zjoi2013]K大数查询-区间第k大[段修改,在线]-树状数组套函数式线段树)

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec   Memory Limit: 512 MB Submit: 418   Solved: 235 [ Submit][ ...

  6. BZOJ 3110 [Zjoi2013]K大数查询(整体二分)

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 11654  Solved: 3505[Submit][St ...

  7. BZOJ.3110.[ZJOI2013]K大数查询(整体二分 树状数组/线段树)

    题目链接 BZOJ 洛谷 整体二分求的是第K小(利用树状数组).求第K大可以转为求第\(n-K+1\)小,但是这样好像得求一个\(n\). 注意到所有数的绝对值\(\leq N\),将所有数的大小关系 ...

  8. [BZOJ 3110] [Zjoi2013] K大数查询 【树套树】

    题目链接: BZOJ - 3110 题目分析 这道题是一道树套树的典型题目,我们使用线段树套线段树,一层是区间线段树,一层是权值线段树.一般的思路是外层用区间线段树,内层用权值线段树,但是这样貌似会很 ...

  9. BZOJ 3110 [Zjoi2013]K大数查询 (CDQ分治+树状数组)

    题目描述 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c如果是2 a b c形式,表示询问从第a个位置到第b个位置,第C大的数是 ...

随机推荐

  1. Angular23 loading组件、路由配置、子路由配置、路由懒加载配置

    1 需求 由于Angular是单页面的应用,所以在进行数据刷新是进行的局部刷新:在进行数据刷新时从浏览器发出请求到后台响应数据是有时间延迟的,所以在这段时间就需要进行遮罩处理来提示用户系统正在请求数据 ...

  2. 50. Pow(x, n) 幂次方

    [抄题]: mplement pow(x, n), which calculates x raised to the power n (xn). Example 1: Input: 2.00000, ...

  3. T-SQL分页功能存储过程

    分页功能存储过程 ALTER PROCEDURE [dbo].[P_SplitPagesQuery] @TablesName NVARCHAR(MAX),--表名或视图名(只能传单一表名) @PK N ...

  4. (转)菜鸟去重复之Sql

    原文地址:http://www.cnblogs.com/fatbird/p/Sql-Remove-duplicate.html 前言 本文主要是总结平时工作学习中遇到的使用Sql Server的去除重 ...

  5. 设计模式05: Prototype 原型模式(创建型模式)

    Prototype 原型模式(创建型模式) 依赖关系的倒置抽象不应该依赖于实现细节,细节应该依赖于抽象.对所有的设计模式都是这样的. -抽象A直接依赖于实现细节b -抽象A依赖于抽象B,实现细节b依赖 ...

  6. Oracle的列操作(增加列,修改列,删除列),包括操作多列

    增加一列: alter table emp4 add test varchar2(10); 修改一列: alter table emp4 modify test varchar2(20); 删除一列: ...

  7. WC 代码统计 java

    GitHub地址 项目需求 实现一个wc统计程序,可以对文本进行相关功能的统计与分析 基本功能 -c 统计字符数 -w 统计文件词数 -l 统计行数 扩展功能 -s 递归搜索目录下面的文件 -a 返回 ...

  8. 使用Sencha Cmd创建脚本框架

    从Ext JS 4.1.1a 开始,为了配合 Sencha Touch开发  而设计了 Sencha Cmd这个跨平台的命令行工具. 要使用Sencha Cmd,必须先安装好 Java Run-tim ...

  9. .Net 项目代码风格规范

    最近没啥时间自己状态也不是很好,公司的事情忙,自己也有一些事情要处理,所以好久没有写博客了.利用公司午休时间写一写,以下是参考了一些资料,整理出来,共勉之. 代码风格没有正确与否,重要的是整齐划一,清 ...

  10. go-spew golang最强大的调试助手,没有之一

    go内置的fmt.sprintf已经很强大了,但是和spew比起来还是相形见绌,这里来一个例子. import ( "fmt" "github.com/davecgh/g ...