题目链接

洛谷

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. 【COCI2012】覆盖字符串

    [题目描述] 给出一个长度为N的小写字母串,现在Mirko有M个若干长度为Li字符串.现在Mirko要用这M个字符串去覆盖给出的那个字符串的.覆盖时,必须保证:1.Mirko的字符串不能拆开,旋转:2 ...

  2. 设置窗口的z-order总是在最底部

    想让窗口置顶,很简单,只需要在SetWindowPos中指定 HWND_TOPMOST就OK了, 但是如果想要窗口始终位于最底端,Windows却没有提供接口. 不过呢,Windows提供了一个消息W ...

  3. mybatis 框架 的简单使用

    # Global logging configuration #在开发环境下日志级别要设置成DEBUG,生产环境设置成info或error log4j.rootLogger=DEBUG, stdout ...

  4. ubuntu 64 14.04 共享文件夹问题

    转自http://blog.csdn.net/gongyuan073/article/details/46604233 原文链接: http://blog.csdn.NET/chinley/artic ...

  5. grid search 超参数寻优

    http://scikit-learn.org/stable/modules/grid_search.html 1. 超参数寻优方法 gridsearchCV 和  RandomizedSearchC ...

  6. 怎样去阅读一份php源代码

    一份好的源代码例如 dz的论坛,wind论坛,帝国cms,dedecms等,都具有自己的一套设计思路和设计模式,所以在看某个产品之前就要做好心理准备,可以把自己的经验和这些产品做对比,但千万别一直用自 ...

  7. [GO]随机数的使用

    package main import ( "math/rand" "time" "fmt" ) func main() { //设置种子, ...

  8. 【Azure Active Directory】单一登录 (SAML 协议)

    Azure Active Directory 支持 SAML 2.0 Web 浏览器单一登录 (SSO) 配置文件. 若要请求 Azure Active Directory 对用户进行身份验证时,云服 ...

  9. DELPHI XE5 跨平台 Form ShowModal 官方示例

    Calling ShowModal as an Anonymous Method on All Platforms procedure THeaderFooterForm.btnPickClick(S ...

  10. 使用Recyclerview实现图片水平自动循环滚动

    简介: 本篇博客主要介绍的是如何使用RecyclerView实现图片水平方向自动循环(跑马灯效果) 效果图: 思路: 1.准备m张图片 1.使用Recyclerview实现,返回无数个(实际Inter ...