题目链接

洛谷

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. 455. Assign Cookies 满足欲望 分配饼干

    [抄题]: Assume you are an awesome parent and want to give your children some cookies. But, you should ...

  2. 58. Length of Last Word最后一个单词的长度

    [抄题]: [暴力解法]: 时间分析: 空间分析: [优化后]: 时间分析: 空间分析: [奇葩输出条件]: [奇葩corner case]: "b a " 最后一位是空格,可能误 ...

  3. Vue.js如何搭建本地dev server和json-server 模拟请求服务器

    前言:vue-cli(版本更新),由原来的2.8.1升级为2.9.1.主要改变是原来在build文件夹下的dev-server.js删掉了,增加了webpack.dev.conf.js. 所以这次讲的 ...

  4. 整合Office Web Apps至自己的开发系统

    原文出处:http://www.cnblogs.com/poissonnotes/p/3267190.html 还可参考:https://www.cnblogs.com/majiang/p/36729 ...

  5. Orace开源的异步IO编程库,特点是接口非常简单

    官网:https://oss.oracle.com/projects/libaio-oracle/,正如标题所说,非常简单了,不用多解释,请直接看头文件,其中aio_poll类似于poll,重要的结构 ...

  6. 模板方法(Template Method)模式

    /* * 抽象模版(AbstractClass)角色有如下的责任: 定义了一个或多个抽象操作,以便让子类实现.这些抽象操作叫做基本操作,它们是一个顶级逻辑的组成步骤. 定义并实现了一个模版方法.这个模 ...

  7. python 读取mysql存储的文件路径下载文件,内容解析,上传七牛云,内容入es

    #!/usr/bin/env python # -*- coding: utf-8 -*- import ConfigParser import json import os import re fr ...

  8. xmlreader与xmlwriter里的几个坑与解决方案

    加载超过100M的xml文件时(可能不是很常见),XmlDocument这种全部加载到内存里的模式就有点不友好了,耗时长.内存高. 这时用xmlreader就会有自行车换超跑的感觉,但其间遇到几个坑, ...

  9. C#开源网络通信库PESocket的使用

    PESocket PESocket开源项目GitHub地址:点击跳转 基于C#语言实现的高效便捷网络库.支持集成到Unity当中使用. 不用过多了解网络通信内部原理,只需几行简单的代码,便能简捷快速开 ...

  10. .Net Core .Net Core的学习

    .Net Core 学习 一.什么是.net core? 百度百科: https://baike.baidu.com/item/.net%20core/20130686?fr=aladdin 个人总结 ...