• <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>
            隨筆 - 87  文章 - 279  trackbacks - 0
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            潛心看書研究!

            常用鏈接

            留言簿(19)

            隨筆分類(81)

            文章分類(89)

            相冊

            ACM OJ

            My friends

            搜索

            •  

            積分與排名

            • 積分 - 216441
            • 排名 - 117

            最新評論

            閱讀排行榜

            評論排行榜

            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 閱讀(937) 評論(1)  編輯 收藏 引用 所屬分類: 數據結構與算法

            FeedBack:
            # re: 線段樹類 2008-11-14 14:19 crg511
            thank you  回復  更多評論
              
            国产精品欧美亚洲韩国日本久久| 国产免费久久精品99re丫y| 亚洲中文字幕无码一久久区| 天天躁日日躁狠狠久久| 久久99国产乱子伦精品免费| 中文字幕亚洲综合久久| 99久久精品国产一区二区 | 亚洲熟妇无码另类久久久| 国产产无码乱码精品久久鸭| 久久久久久噜噜精品免费直播| 久久久久久国产a免费观看黄色大片| 人妻少妇久久中文字幕一区二区 | 青青青伊人色综合久久| 狠狠色丁香婷婷久久综合五月| 青青草原综合久久| 久久亚洲精品成人av无码网站| 亚洲?V乱码久久精品蜜桃| 26uuu久久五月天| 97久久精品人妻人人搡人人玩| 久久久久无码中| 99久久亚洲综合精品网站| 欧美精品久久久久久久自慰| 久久嫩草影院免费看夜色| 青青青国产成人久久111网站| 久久精品国产久精国产果冻传媒| 久久99精品久久久久久齐齐| 久久亚洲国产欧洲精品一| 国产精品一区二区久久不卡| 亚洲狠狠婷婷综合久久蜜芽| 久久AV无码精品人妻糸列| 日韩欧美亚洲综合久久 | 亚洲伊人久久综合影院| 久久人人爽人爽人人爽av| 国产午夜精品久久久久九九电影 | 亚洲人成网站999久久久综合 | 久久精品亚洲精品国产欧美| 国产精品综合久久第一页| 精品水蜜桃久久久久久久| 久久人人爽人人爽AV片| 久久黄视频| 欧美日韩精品久久免费|