青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

統計的力量

Posted on 2013-09-13 13:29 Mato_No1 閱讀(1927) 評論(4)  編輯 收藏 引用 所屬分類: 線段樹
Orz zkw!!!

最近看完了《統計的力量》……覺得這實在是太神了……原來線段樹可以這么寫……

zkw線段樹的思想:先將線段長度N變為2的整數次方,使線段樹成為滿二叉樹,然后就可以通過各種位運算直接鏈接到某個結點,不必遞歸了,因此大大減小了常數……

本沙茶利用zkw線段樹在BZOJ1756和1798上都刷到了rank3……
代碼:
<1>BZOJ1756:
#include <iostream>
#include 
<stdio.h>
#include 
<stdlib.h>
#include 
<string.h>
using namespace std;
#define re(i, n) for (int i=0; i<n; i++)
#define re1(i, n) for (int i=1; i<=n; i++)
#define re2(i, l, r) for (int i=l; i<r; i++)
#define re3(i, l, r) for (int i=l; i<=r; i++)
#define rre(i, n) for (int i=n-1; i>=0; i--)
#define rre1(i, n) for (int i=n; i>0; i--)
#define rre2(i, r, l) for (int i=r-1; i>=l; i--)
#define rre3(i, r, l) for (int i=r; i>=l; i--)
#define ll long long
const int MAXN = (1 << 19+ 10, INF = ~0U >> 2;
struct node {
    
int sum, lv, rv, v;
} T[MAXN 
<< 1];
int n, N, A[MAXN], Z[MAXN], res;
inline 
int get_int()
{
    
int x; char ch; bool FF;
    
while ((ch = getchar()) < 48 && ch != '-') ;
    
if (ch == '-') {FF = 1; x = 0;} else {FF = 0; x = ch - 48;}
    
while ((ch = getchar()) >= 48) x = x * 10 + ch - 48;
    
if (FF) x = -x; return x;
}
void prepare()
{
    N 
= n << 1;
    re2(i, n, N) T[i].sum 
= T[i].lv = T[i].rv = T[i].v = A[i - n];
    
for (int i=0; (1<<i)<=n; i++) Z[1 << i] = i;
    
int lch, rch, _;
    rre2(i, n, 
1) {
        lch 
= i << 1; rch = lch ^ 1;
        T[i].sum 
= T[lch].sum + T[rch].sum;
        T[i].lv 
= (_ = T[lch].sum + T[rch].lv) >= T[lch].lv ? _ : T[lch].lv;
        T[i].rv 
= (_ = T[rch].sum + T[lch].rv) >= T[rch].rv ? _ : T[rch].rv;
        T[i].v 
= T[lch].v >= T[rch].v ? T[lch].v : T[rch].v;
        
if ((_ = T[lch].rv + T[rch].lv) >= T[i].v) T[i].v = _;
    }
}
void opr0(int pos, int x)
{
    
int i = pos + n; T[i].sum = T[i].lv = T[i].rv = T[i].v = x; int _, __ = x - A[pos], lch, rch; A[pos] = x;
    
for (i>>=1; i; i>>=1) {
        lch 
= i << 1; rch = lch ^ 1;
        T[i].sum 
+= __;
        T[i].lv 
= (_ = T[lch].sum + T[rch].lv) >= T[lch].lv ? _ : T[lch].lv;
        T[i].rv 
= (_ = T[rch].sum + T[lch].rv) >= T[rch].rv ? _ : T[rch].rv;
        T[i].v 
= T[lch].v >= T[rch].v ? T[lch].v : T[rch].v;
        
if ((_ = T[lch].rv + T[rch].lv) >= T[i].v) T[i].v = _;
    }
}
void opr1(int l, int r)
{
    
int sum0 = 0, l0, i, _; l |= n; r |= n; r++; res = -INF;
    
for (; l0=l, (l+=l&-l)<=r; ) {
        i 
= l0 / (l0 & -l0);
        
if (T[i].v > res) res = T[i].v;
        
if ((_ = sum0 + T[i].lv) > res) res = _;
        sum0 
+= T[i].sum; if (T[i].rv > sum0) sum0 = T[i].rv;
    }
    
int s = (l0 & -l0) >> 1, z = Z[s];
    
for (; l0<r; s>>=1, z--if ((l = l0 + s) <= r) {
        i 
= l0 >> z;
        
if (T[i].v > res) res = T[i].v;
        
if ((_ = sum0 + T[i].lv) > res) res = _;
        sum0 
+= T[i].sum; if (T[i].rv > sum0) sum0 = T[i].rv;
        l0 
= l;
    }
}
int main()
{
    
int n0, m, x, y, z;
    n0 
= get_int(); m = get_int(); re(i, n0) A[i] = get_int(); for (n=1; n<n0; n<<=1) ;
    prepare();
    re(i, m) {
        x 
= get_int(); y = get_int(); z = get_int();
        
if (x == 1) {if (y > z) {x = y; y = z; z = x;} opr1(--y, --z); printf("%d\n", res);} else opr0(--y, z);
    }
    
return 0;
}


<2>BZOJ1798:
#include <iostream>
#include 
<stdio.h>
#include 
<stdlib.h>
#include 
<string.h>
using namespace std;
#define re(i, n) for (int i=0; i<n; i++)
#define re1(i, n) for (int i=1; i<=n; i++)
#define re2(i, l, r) for (int i=l; i<r; i++)
#define re3(i, l, r) for (int i=l; i<=r; i++)
#define rre(i, n) for (int i=n-1; i>=0; i--)
#define rre1(i, n) for (int i=n; i>0; i--)
#define rre2(i, r, l) for (int i=r-1; i>=l; i--)
#define rre3(i, r, l) for (int i=r; i>=l; i--)
#define ll long long
const int MAXN = (1 << 17+ 10;
struct node {
    ll mr0, mr1, sum;
    
int len;
} T[MAXN 
<< 1];
int n, s, N, A[MAXN];
ll MOD, res;
inline 
int get_int()
{
    
char ch; int x;
    
while ((ch = getchar()) < 48) ;
    x 
= ch - 48while ((ch = getchar()) > 47) x = x * 10 + ch - 48;
    
return x;
}
void prepare()
{
    N 
= n << 1int lch, rch;
    re2(i, n, N) {T[i].mr0 
= 1; T[i].sum = A[i - n] % MOD; T[i].len = 0;}
    rre2(i, n, 
1) {
        lch 
= i << 1; rch = lch ^ 1; T[i].len = T[lch].len + 1;
        T[i].mr0 
= 1; T[i].sum = T[lch].sum + T[rch].sum; if (T[i].sum >= MOD) T[i].sum -= MOD;
    }
}
inline 
void dm(int i)
{
    
int lch = i << 1, rch = lch ^ 1; ll c0;
    
if ((c0 = T[i].mr0) ^ 1) {
        T[i].mr0 
= 1;
        T[lch].mr0 
= T[lch].mr0 * c0 % MOD; T[lch].mr1 = T[lch].mr1 * c0 % MOD; T[lch].sum = T[lch].sum * c0 % MOD;
        T[rch].mr0 
= T[rch].mr0 * c0 % MOD; T[rch].mr1 = T[rch].mr1 * c0 % MOD; T[rch].sum = T[rch].sum * c0 % MOD;
    }
    
if (c0 = T[i].mr1) {
        T[i].mr1 
= 0;
        T[lch].mr1 
+= c0; if (T[lch].mr1 >= MOD) T[lch].mr1 -= MOD; T[lch].sum = (T[lch].sum + (c0 << T[lch].len)) % MOD;
        T[rch].mr1 
+= c0; if (T[rch].mr1 >= MOD) T[rch].mr1 -= MOD; T[rch].sum = (T[rch].sum + (c0 << T[rch].len)) % MOD;
    }
}
void opr0(int l, int r, ll c)
{
    
int k, l0 = l | n, r0 = r | n, i, j, lch, rch; ll c0;
    
for (k=s-1; k&&(i=l0>>k)==r0>>k; k--) dm(i);
    
for (int k0=k; ((i=l0>>k0)<<k0)^l0; k0--) dm(i);
    
for (int k0=k; (((i=r0>>k0)<<k0)|((1<<k0)-1))^r0; k0--) dm(i);
    r0
++int l1;
    
for (; l1=l0, (l0+=l0&-l0)<=r0; ) {
        i 
= l1 / (l1 & -l1);
        T[i].mr0 
= T[i].mr0 * c % MOD; T[i].mr1 = T[i].mr1 * c % MOD; T[i].sum = T[i].sum * c % MOD;
    }
    
int _ = (l1 & -l1) >> 1, z = __builtin_ctz(_);
    
for (; l1<r0; _>>=1, z--if (l1 + _ <= r0) {
        i 
= l1 >> z;
        T[i].mr0 
= T[i].mr0 * c % MOD; T[i].mr1 = T[i].mr1 * c % MOD; T[i].sum = T[i].sum * c % MOD;
        l1 
+= _;
    }
    l0 
= l | n; r0 = r | n;
    
for (k=0; (i=l0>>k)^(j=r0>>k); k++) {
        
if ((i << k) ^ l0) {T[i].sum = T[i << 1].sum + T[(i << 1^ 1].sum; if (T[i].sum >= MOD) T[i].sum -= MOD;}
        
if (((j << k) | ((1 << k) - 1)) ^ r0) {T[j].sum = T[j << 1].sum + T[(j << 1^ 1].sum; if (T[j].sum >= MOD) T[j].sum -= MOD;}
    }
    
for (; k<s; k++) {
        i 
= l0 >> k;
        
if ((i << k) ^ l0 || ((j << k) | ((1 << k) - 1)) ^ r0) {T[i].sum = T[i << 1].sum + T[(i << 1^ 1].sum; if (T[i].sum >= MOD) T[i].sum -= MOD;}
    }
}
void opr1(int l, int r, ll c)
{
    
int k, l0 = l | n, r0 = r | n, i, j, lch, rch; ll c0;
    
for (k=s-1; k&&(i=l0>>k)==r0>>k; k--) dm(i);
    
for (int k0=k; ((i=l0>>k0)<<k0)^l0; k0--) dm(i);
    
for (int k0=k; (((i=r0>>k0)<<k0)|((1<<k0)-1))^r0; k0--) dm(i);
    r0
++int l1;
    
for (; l1=l0, (l0+=l0&-l0)<=r0; ) {
        i 
= l1 / (l1 & -l1);
        T[i].mr1 
+= c; if (T[i].mr1 >= MOD) T[i].mr1 -= MOD; T[i].sum = (T[i].sum + (c << T[i].len)) % MOD;
    }
    
int _ = (l1 & -l1) >> 1, z = __builtin_ctz(_);
    
for (; l1<r0; _>>=1, z--if (l1 + _ <= r0) {
        i 
= l1 >> z;
        T[i].mr1 
+= c; if (T[i].mr1 >= MOD) T[i].mr1 -= MOD; T[i].sum = (T[i].sum + (c << T[i].len)) % MOD;
        l1 
+= _;
    }
    l0 
= l | n; r0 = r | n;
    
for (k=0; (i=l0>>k)^(j=r0>>k); k++) {
        
if ((i << k) ^ l0) {T[i].sum = T[i << 1].sum + T[(i << 1^ 1].sum; if (T[i].sum >= MOD) T[i].sum -= MOD;}
        
if (((j << k) | ((1 << k) - 1)) ^ r0) {T[j].sum = T[j << 1].sum + T[(j << 1^ 1].sum; if (T[j].sum >= MOD) T[j].sum -= MOD;}
    }
    
for (; k<s; k++) {
        i 
= l0 >> k;
        
if ((i << k) ^ l0 || ((j << k) | ((1 << k) - 1)) ^ r0) {T[i].sum = T[i << 1].sum + T[(i << 1^ 1].sum; if (T[i].sum >= MOD) T[i].sum -= MOD;}
    }
}
void opr2(int l, int r)
{
    res 
= 0;
    
int k, l0 = l | n, r0 = r | n, i, j, lch, rch; ll c0;
    
for (k=s-1; k&&(i=l0>>k)==r0>>k; k--) dm(i);
    
for (int k0=k; ((i=l0>>k0)<<k0)^l0; k0--) dm(i);
    
for (int k0=k; (((i=r0>>k0)<<k0)|((1<<k0)-1))^r0; k0--) dm(i);
    r0
++int l1, r1;
    
for (; l1=l0, (l0+=l0&-l0)<=r0; ) {
        i 
= l1 / (l1 & -l1); res += T[i].sum;
    }
    
int _ = (l1 & -l1) >> 1, z = __builtin_ctz(_);
    
for (; l1<r0; _>>=1, z--if (l1 + _ <= r0) {
        i 
= l1 >> z; res += T[i].sum;
        l1 
+= _;
    }
    res 
%= MOD;
}
int main()
{
    
int n0 = get_int(); MOD = get_int(); re(i, n0) A[i] = get_int(); for (n=1, s=0; n<n0; n<<=1, s++) ; s++;
    prepare(); 
int M, _, l, r, c; M = get_int();
    re(i, M) {
        _ 
= get_int(); l = get_int(); r = get_int(); l--; r--;
        
if (_ == 1) {
            c 
= get_int() % MOD; opr0(l, r, c);
        } 
else if (_ == 2) {
            c 
= get_int() % MOD; opr1(l, r, c);
        } 
else {
            opr2(l, r); printf(
"%d\n", (int) res);
        }
    }
    
return 0;
}

Feedback

# re: 統計的力量  回復  更多評論   

2013-09-15 17:26 by taorunz
樹狀數組的推廣

# re: 統計的力量  回復  更多評論   

2013-09-15 17:27 by taorunz
不能區間修改區間查詢怎么辦

# re: 統計的力量  回復  更多評論   

2013-09-21 15:58 by Mato_No1
@taorunz
zkw線段樹可以支持標記。

# re: 統計的力量  回復  更多評論   

2013-11-04 21:26 by ht
@Mato_No1
打標記測試速度和普通差不多?
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久久99国产精品免费| 欧美一区二区三区在线免费观看| 亚洲精品视频啊美女在线直播| 国产精品欧美一区二区三区奶水| 欧美日韩国产免费| 欧美性色aⅴ视频一区日韩精品| 欧美精品一区二区三区蜜桃| 欧美一区二区在线观看| 亚洲一区三区视频在线观看| 亚洲视频在线观看免费| 亚洲免费在线看| 久久成人国产| 久久久久中文| 欧美在线在线| 性欧美大战久久久久久久免费观看| 99精品久久久| 亚洲免费影视第一页| 一区二区三区久久网| 亚洲精品久久7777| 欧美日韩日日骚| 欧美激情一区二区三区在线视频观看| 久久综合九色九九| 欧美a级一区二区| 日韩视频二区| 欧美aa国产视频| 精品88久久久久88久久久| 国产精品久久7| 免费久久99精品国产| 久久―日本道色综合久久| 夜久久久久久| 亚洲欧美日韩综合aⅴ视频| 亚洲素人一区二区| 久久精品亚洲一区二区| 蜜臀av国产精品久久久久| 欧美精品二区三区四区免费看视频| 欧美在线视频免费| 亚洲午夜精品久久| 欧美在线不卡视频| 蜜桃伊人久久| 欧美新色视频| 在线观看欧美激情| 亚洲无线观看| 久久亚洲春色中文字幕久久久| 麻豆精品网站| 日韩图片一区| 久久久www成人免费毛片麻豆| 蜜桃久久精品一区二区| 欧美午夜电影网| 一区视频在线看| 在线视频一区二区| 久久久亚洲高清| 亚洲激情视频| 亚洲大片免费看| 欧美福利视频一区| 亚洲国产清纯| 亚洲另类黄色| 在线亚洲自拍| 欧美一级片一区| 亚洲第一中文字幕| 欧美一区二区国产| 国产精品高潮呻吟视频| 亚洲激情网站免费观看| 亚洲欧美日韩国产综合在线 | 今天的高清视频免费播放成人 | 欧美阿v一级看视频| 一本一本a久久| 久久精品99| 欧美色网一区二区| 亚洲成色999久久网站| 午夜精品免费在线| 91久久精品一区二区三区| 欧美中文字幕不卡| 欧美性淫爽ww久久久久无| 最近看过的日韩成人| 久久婷婷成人综合色| 日韩一区二区精品视频| 蜜桃久久av一区| 一区二区三区在线高清| 性欧美长视频| 一区二区三区高清| 欧美三级视频在线播放| 欧美国产精品久久| 国产午夜精品久久久久久免费视| 99av国产精品欲麻豆| 免费永久网站黄欧美| 久久久www| 亚洲丰满少妇videoshd| 老司机67194精品线观看| 欧美在线视频二区| 欧美一进一出视频| 国产一区二区三区免费在线观看| 亚洲三级影片| 噜噜爱69成人精品| 亚洲卡通欧美制服中文| 另类酷文…触手系列精品集v1小说| 国产伦精品一区二区三区四区免费| 在线视频成人| 裸体素人女欧美日韩| 亚洲欧美清纯在线制服| 久久精品亚洲一区二区| 黄色成人在线| 亚洲大胆人体在线| 欧美日韩在线一二三| 一区二区三区四区在线| 狼人天天伊人久久| 久久久久se| 亚洲欧美综合国产精品一区| 亚洲欧美中文日韩在线| 在线观看欧美亚洲| 日韩一级裸体免费视频| 国产欧美日韩亚洲一区二区三区| 久久久99国产精品免费| 麻豆精品一区二区av白丝在线| 最新亚洲一区| 国产精品99久久久久久www| 国产亚洲成年网址在线观看| 欧美成年视频| 国产精品国产三级国产普通话蜜臀 | 亚洲片区在线| 99精品视频一区二区三区| 免费成人在线视频网站| 欧美在线高清视频| 亚洲欧美日韩另类| 国产日韩av高清| 久久精品最新地址| 久久九九精品99国产精品| 国产欧美一区二区精品忘忧草| 久久人人爽人人爽| 欧美精品一卡二卡| 欧美视频三区在线播放| 久久久国产精彩视频美女艺术照福利 | 欧美在线视频一区二区| 女生裸体视频一区二区三区| 性欧美videos另类喷潮| 欧美第一黄网免费网站| 久久精品99| 久久露脸国产精品| 亚洲男人的天堂在线观看| 麻豆精品视频在线观看视频| 国产精品老牛| 亚洲精品一区二区三区蜜桃久| 国语自产精品视频在线看8查询8| 亚洲毛片av在线| 亚洲黄色小视频| 久久久激情视频| 午夜精品视频一区| 亚洲精品日韩在线| 亚洲国产二区| 久久琪琪电影院| 久久久蜜桃一区二区人| 国产精品久久波多野结衣| 亚洲精品美女在线| 国产手机视频精品| 亚洲成在人线av| 蜜臀av性久久久久蜜臀aⅴ| 亚洲高清网站| 久久aⅴ国产欧美74aaa| 久久精品在线播放| 国产性猛交xxxx免费看久久| 亚洲欧美成人综合| 午夜视频在线观看一区二区| 国产精品地址| 亚洲图片激情小说| 亚洲一区二区三区四区五区黄| 欧美日韩精品国产| 亚洲精品久久视频| 亚洲精品无人区| 欧美日韩不卡合集视频| 亚洲精品欧美一区二区三区| 一区二区高清视频| 欧美午夜不卡影院在线观看完整版免费 | 欧美另类在线观看| 欧美在线综合| 女仆av观看一区| 久久久噜噜噜久噜久久| 国产精品欧美经典| 午夜亚洲福利| 久久蜜桃精品| 欧美三级日本三级少妇99| 国产午夜精品全部视频在线播放| 亚洲国产精品综合| 99re这里只有精品6| 欧美日韩国产色综合一二三四 | 亚洲女人天堂成人av在线| 国产精品美女久久福利网站| 午夜精品理论片| 米奇777超碰欧美日韩亚洲| 亚洲日本乱码在线观看| 欧美视频免费| 久久国产夜色精品鲁鲁99| 欧美激情bt| 亚洲在线黄色| 激情成人亚洲| 欧美区日韩区| 亚洲精品国精品久久99热| 精品电影在线观看| 欧美91视频| 欧美www在线| 亚洲午夜高清视频| 怡红院av一区二区三区|