#include#include#include#include#include#defineREP(i,n)for(i=0;i<(n);++i)#defineint64longlong#defineoo0x13131313#definemaxn50005#defineMax(a,b)(a>b?a:b)#defineMin(a,b)(a

欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

[zjoi2013]k大數(shù)查詢

系統(tǒng) 2044 0
    #include <cstdio>

#include <cstdlib>

#include <cmath>

#include <cstring>

#include <ctime>

#include <algorithm>

   

#define REP(i, n) for (i = 0; i < (n); ++i)

#define int64 long long

#define oo 0x13131313

#define maxn 50005

#define Max(a, b) (a > b ? a : b)

#define Min(a, b) (a < b ? a : b)

   

using namespace std;

   

struct node { int s, t; node *c[2]; } null[maxn * 100], *nt = null;

struct seg { node *R; seg *c[2]; } ss[maxn * 2], *st = ss, *root;

int n, m, L, R;

   

void modify(node *&p, int l, int r)

{

    if (!p || p == null) p = ++nt, p->c[0] = p->c[1] = null;

    if (L <= l && r <= R) { p->s += r - l + 1, ++p->t; return; }

    int mid = (l + r) >> 1;

    if (L <= mid) modify(p->c[0], l, mid);

    if (R > mid) modify(p->c[1], mid + 1, r);

    p->s += Min(R, r) - Max(L, l) + 1;

}

   

int ask(node *p, int l, int r)

{

    if (!p || p == null) return 0;

    if (L <= l && r <= R) return p->s;

    int res = 0, mid = (l + r) >> 1;

    if (L <= mid) res += ask(p->c[0], l, mid);

    if (R > mid) res += ask(p->c[1], mid + 1, r);

    return res + p->t * (Min(R, r) - Max(L, l) + 1);

}

   

void build(seg *p, int l, int r)

{

    if (l == r) return;

    build(p->c[0] = ++st, l, (l + r) >> 1);

    build(p->c[1] = ++st, ((l + r) >> 1) + 1, r);

}

   

void modify(int a, int b, int c)

{

    int l = 1, r = n; seg *p = root; L = a, R = b;

    for (; modify(p->R, 1, n), l < r; )

        p = c > (l + r) >> 1 ?

            (l = ((l + r) >> 1) + 1, p->c[1]) : (r = (l + r) >> 1, p->c[0]);

}

   

int ask(int a, int b, int c)

{

    int l = 1, r = n; seg *p = root; L = a, R = b;

    for (; l < r; ) {

        int k = ask(p->c[1]->R, 1, n);

        p = k < c ? (r = (l + r) >> 1, c -= k, p->c[0]) : (l = ((l + r) >> 1) + 1, p->c[1]);

    }

    return l;

}

   

int main()

{

    freopen("sequence.in", "r", stdin);

    freopen("sequence.out", "w", stdout);

   

    scanf("%d%d", &n, &m);

    build(root = ++st, 1, n);

    for (; m--; ) {

        int t, a, b, c;

        scanf("%d%d%d%d", &t, &a, &b, &c);

        t == 1 ? modify(a, b, c), 1 : printf("%d\n", ask(a, b, c));

    }

}
  


[zjoi2013]k大數(shù)查詢


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产精品19禁在线观看2021 | 日本高清乱理伦片中文字幕啊 | www.妞干网.com | 欧美一级毛片高清免费观看 | 色综合加勒比 | 午夜大片 | 日本黄色网战 | 69av亚洲| 91短视频app下载 | 欧美在线观看视频一区 | 久久伊人免费视频 | 亚洲精品福利一区二区三区 | av在线播放网址 | 奇米影视 首页 | 九九99国产精品视频 | 国产亚洲蜜芽精品久久 | 欧美日韩中文在线观看 | 久久久久国产精品免费免费搜索 | 免费视频日韩 | 老色鬼久久AV综合亚洲健身 | 成人看片| 成人av在线播放 | 九九热在线精品视频 | 97网站 | 成人 在线| 精品一区中文字幕 | 国产乱码精品一区二区三区中 | 亚洲天堂影院 | 毛片毛片毛片毛片毛片毛片毛片 | 看中国毛片 | 欧美视频大全 | 国产色情A片国语露对白 | 成人免费毛片视频 | 日本亚洲精品色婷婷在线影院 | 2022最新a精品视频在线观看 | 日本中文字幕不卡 | 国产亚洲精品久久无亚洲 | 色噜噜亚洲男人的天堂 | 亚洲综合色丁香婷婷六月图片 | 日本免费观看官网 | 欧美日韩xxx |