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

隨筆 - 87  文章 - 279  trackbacks - 0
<2008年4月>
303112345
6789101112
13141516171819
20212223242526
27282930123
45678910

潛心看書研究!

常用鏈接

留言簿(19)

隨筆分類(81)

文章分類(89)

相冊

ACM OJ

My friends

搜索

  •  

積分與排名

  • 積分 - 220432
  • 排名 - 118

最新評論

閱讀排行榜

評論排行榜

const int MAXN = 50000;
 
class SegmentTree {
public:
      int LSON[MAXN]; //LSON[i]為節點i的左兒子的序號
      int RSON[MAXN]; //RSON[i]為節點i的右兒子的序號
      int B[MAXN]; //B[i]為區間i左端點
      int E[MAXN]; //E[i]為區間i右端點
      int cnt[MAXN]; //cnt[i]為區間i的計數器
      int M[MAXN]; //M[i]為區間i的測度
      int lbd[MAXN]; //lbd[i]為區間i的左端點是否被覆蓋
      int rbd[MAXN]; //rbd[i]為區間i的右端點是否被覆蓋
      int lines[MAXN]; //lines[i]為區間i的連續線段數
      int root; //樹根 初始化時候設為1
      int n; //樹的節點數
      SegmentTree(int, int);
      void build(int, int);
      void insert(int, int, int);
      void del(int, int, int);
      void updateM(int); //更新測度
      void updateLines(int); //更新連續線段數
};
SegmentTree::SegmentTree(int a, int b) {
      root = 1;
      n = 0;
      memset(LSON, 0, sizeof(LSON));
      memset(RSON, 0, sizeof(RSON));
      memset(cnt, 0, sizeof(cnt));
      memset(M, 0, sizeof(M));
      memset(lines, 0, sizeof(lines));
      memset(lbd, 0, sizeof(lbd));
      memset(rbd, 0, sizeof(rbd));
      build(a, b);
}
void SegmentTree::build(int a, int b) {
      n += 1;
      int v = n;
      B[v] = a; E[v] = b; 
      if (b - a > 1) {
            LSON[v] = n + 1;
            build(a, (a+b)/2);
            RSON[v] = n + 1;
            build((a+b)/2, b);
      }
}
void SegmentTree::insert(int a, int b, int v) {
      if (!v) return ;
      if (a <= B[v] && E[v] <= b) {
            cnt[v]++;
            lbd[v] = rbd[v] = 1;
      } else if (E[v]-B[v] > 1) {
            if (a <(b[v]+e[v])/2) insert(a, b, LSON[v]);
            if (b > (B[v]+E[v])/2) insert(a, b, RSON[v]);
      }
      updateM(v);
      updateLines(v);
}
void SegmentTree::del(int a, int b, int v) {
      if (!v) return ;
      if (a <= B[v] && E[v] <= b) {
            cnt[v]--;
            if (a == B[v]) lbd[v] = 0;
            if (b == E[v]) rbd[v] = 0;
      } else if (E[v]-B[v] > 1) {
            if (a <(b[v]+e[v])/2) del(a, b, LSON[v]);
            if (b > (B[v]+E[v])/2) del(a, b, RSON[v]);
      }
      updateM(v);
      updateLines(v);
}
void SegmentTree::updateM(int v) {
      if (cnt[v] > 0) M[v] = E[v] - B[v];
      else {
            if (E[v]-B[v] == 1) M[v] = 0;
            else M[v] = M[LSON[v]] + M[RSON[v]];
      }
}
void SegmentTree::updateLines(int v) {
      if (cnt[v] > 0) lbd[v] = rbd[v] = lines[v] = 1;
      else {
            if (E[v]-B[v] == 1) lbd[v] = rbd[v] = lines[v] = 0;
            else {
                  lbd[v] = lbd[LSON[v]]; rbd[v] = rbd[RSON[v]];
                  lines[v] = lines[LSON[v]] + lines[RSON[v]] - rbd[LSON[v]] * lbd[RSON[v]];
            }
      }
}
posted on 2007-04-07 12:16 閱讀(961) 評論(1)  編輯 收藏 引用 所屬分類: 數據結構與算法

FeedBack:
# re: 線段樹類 2008-11-14 14:19 crg511
thank you  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              久久精品二区三区| 一本色道久久综合亚洲精品不| 黄色国产精品一区二区三区| 国产日韩欧美综合一区| 亚洲欧美另类在线观看| 久久久欧美一区二区| 亚洲视频1区| 亚洲免费观看在线观看| 国产噜噜噜噜噜久久久久久久久| 欧美成人69| 激情校园亚洲| 欧美三级第一页| 欧美一区国产在线| 99国产精品| 亚洲精品永久免费精品| 免费亚洲一区二区| 欧美黑人在线观看| 免费欧美高清视频| 免费不卡中文字幕视频| 久久亚洲国产成人| 9色精品在线| 欧美特黄视频| 国产伦精品一区二区三区视频孕妇 | 亚洲国产精品ⅴa在线观看| 一本一本a久久| 一区二区三区久久久| 亚洲欧美日韩直播| 久久久99爱| 免费短视频成人日韩| 欧美a级大片| 亚洲伦理网站| 亚洲欧美视频在线观看| 欧美一级视频免费在线观看| 久久阴道视频| 国产精品欧美激情| 亚洲免费av片| 麻豆国产精品一区二区三区 | 亚洲成人中文| 欧美一区二区三区精品电影| 欧美黄网免费在线观看| 亚洲男女毛片无遮挡| 欧美/亚洲一区| 国产在线麻豆精品观看| 亚洲欧美日韩一区二区三区在线观看 | 激情国产一区二区| 亚洲欧美日本在线| 亚洲激情小视频| 久久激情视频| 国产日韩成人精品| 亚洲影院一区| 亚洲黄色一区二区三区| 久久久亚洲国产天美传媒修理工| 国产精品户外野外| 一区二区三区免费看| 欧美高清不卡| 久久久久在线| 精品福利电影| 久久综合色88| 久久亚洲图片| 亚洲国产高清在线观看视频| 欧美成人免费在线观看| 亚洲免费在线精品一区| 激情久久中文字幕| 久久久久国产精品一区二区| 亚洲综合999| 亚洲欧美日韩中文在线制服| 欧美成人三级在线| 在线观看成人网| 麻豆精品在线观看| 欧美在线视频一区二区| 国产精品入口尤物| 亚洲天天影视| 鲁大师影院一区二区三区| 欧美日韩网址| 亚洲精品中文字幕女同| 欧美激情区在线播放| 久久一区二区三区四区| 国产精品日本一区二区| 亚洲亚洲精品在线观看 | 亚洲人体1000| 久久九九免费| 在线视频免费在线观看一区二区| 亚洲视频欧美在线| 亚洲激情在线播放| 亚洲一区二区在| 在线免费观看欧美| 午夜欧美精品| 亚洲欧美日韩一区二区在线 | 欧美大片国产精品| 欧美gay视频激情| 精品动漫一区| 久久狠狠亚洲综合| 国内激情久久| 国产精品欧美日韩| 亚洲午夜精品久久| 亚洲一区二区三区激情| 亚洲性夜色噜噜噜7777| 国内外成人免费激情在线视频网站| 另类图片国产| 欧美日韩亚洲综合一区| 久久精品国产亚洲5555| 欧美a级大片| 亚洲一级网站| 久久久在线视频| 韩国一区电影| 亚洲自拍偷拍网址| 久久这里只精品最新地址| 国产精品丝袜白浆摸在线| 亚洲国产日韩一区二区| 国外成人在线视频网站| 在线亚洲免费| 欧美在线黄色| 国产精品久久网| 亚洲影院在线| 久久国产精品久久国产精品| 国产性色一区二区| 久久手机精品视频| 一区二区三区回区在观看免费视频| 亚洲免费影院| 亚洲国产一区二区精品专区| 欧美精品网站| 久久综合色88| 亚洲男人第一av网站| 麻豆成人在线播放| 欧美一区二区在线免费观看| 一区二区三区久久精品| 国产一区二区三区精品欧美日韩一区二区三区 | 久久综合九色| 欧美顶级艳妇交换群宴| 欧美aaa级| 亚洲欧美在线另类| 国产欧美日韩中文字幕在线| 亚洲第一成人在线| 欧美日韩亚洲高清| 欧美大片在线观看| 欧美亚洲网站| 亚洲香蕉伊综合在人在线视看| 欧美成人午夜激情视频| 国产一区二区剧情av在线| 亚洲免费网站| 性欧美暴力猛交另类hd| 欧美午夜精品一区| 亚洲免费在线播放| 亚洲一区二区三区四区在线观看| 在线观看欧美亚洲| 国产一级久久| 亚洲激情视频在线播放| 狠狠色狠狠色综合日日五| 欧美日韩中文精品| 亚洲二区视频| 欧美粗暴jizz性欧美20| 久久一区中文字幕| 欧美电影免费观看大全| 亚洲国产第一页| av成人毛片| 亚洲欧美在线播放| 老司机一区二区| 欧美日韩亚洲另类| 国产亚洲成年网址在线观看| 1024国产精品| 亚洲欧美精品在线观看| 老司机亚洲精品| 一区二区三区毛片| 久久久久成人网| 永久久久久久| 亚洲美女福利视频网站| 亚洲制服少妇| 欧美一区二区精美| 老司机精品久久| 国产精品免费久久久久久| 久久夜色精品| 欧美精品一区二区三区高清aⅴ| 欧美日本韩国在线| 欧美激情第9页| 亚洲免费高清| 一区二区三区在线视频观看| 欧美午夜剧场| 亚洲视频国产视频| 鲁大师成人一区二区三区| 亚洲毛片在线| 国产一区二区精品丝袜| 欧美高清在线播放| 亚洲欧美在线免费| 亚洲开发第一视频在线播放| 久久精品日韩一区二区三区| 亚洲精品日韩在线观看| 国产深夜精品福利| 欧美日韩亚洲一区在线观看| 欧美淫片网站| 一区二区日韩精品| 亚洲第一毛片| 久久亚洲电影| 午夜精品久久久久久99热软件| 在线成人h网| 国产日韩欧美视频| 欧美日韩三区| 欧美成人精品一区二区| 久久福利电影| 午夜精品在线看| 夜夜嗨av色综合久久久综合网|