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

Try Again

基礎知識學習
隨筆 - 4, 文章 - 0, 評論 - 0, 引用 - 0
數據加載中……

線段樹

#include <iostream>
#include 
<string>
#include 
<algorithm>
using namespace std;

const int SIZE = 10010;

struct node // the node of line tree
{
    
int i,j; // 區間范圍
    node * lson;
    node 
* rson;
    
int count; // 線段覆蓋條數
    int m; // 測度
    int line; // 連續段數
    int lbd,rbd; // 用來計算連續段數
    node(int l,int r)
    {
        i 
= l,j = r;
        count 
= m = line = lbd = rbd = 0;
        lson 
= rson = NULL;
    }
};
class LineTree
{
    node 
* head;
    
/* 以下函數內部使用,可不用考慮 */
    
void init(node * pnode = NULL)
    {
        head 
= pnode;
    }
    
void updateM()
    {
        
if (head->count > 0// 被覆蓋滿
            head->= head->- head->i;
        
else if (head->- head->== 1// 該節點為葉節點
            head->= 0;
        
else    // 其他內部節點的情況
            head->= (head->lson)->+ (head->rson)->m;
    }
    
void updateLine()
    {
        
if (head->count > 0)
            head
->lbd = head->rbd = head->line = 1;
        
else if (head->- head->== 1)
            head
->lbd = head->rbd = head->line = 0;
        
else
        {
            head
->lbd = (head->lson)->lbd;
            head
->rbd = (head->rson)->rbd;
            head
->line = (head->lson)->line + (head->rson)->line - (head->lson)->rbd * (head->rson)->lbd;
        }
    }
public:
    LineTree();
    
void clear(); // 清空線段數;
    void build(int l,int r); // 建立線段樹,區間[l,r];
    void insert(int l,int r); // 插入一條線段;
    void del(int l,int r); // 刪除一條線段;
    int GetM(); // 測度;
    int GetLine(); // 連續段數;
    int GetCov(); // 覆蓋線段數;
    ~LineTree();
};
LineTree::LineTree()
{
    head 
= NULL;
}
void LineTree::clear() // 清空線段數
{
    
if (head == NULL)
        
return;
    LineTree temp;
    temp.init(head
->lson);
    temp.clear();
    temp.init(head
->rson);
    temp.clear();
    delete head;
    head 
= NULL;
}
void LineTree::build(int l,int r) // 建立線段樹,區間[l,r]
{
    head 
= new node(l,r);
    
if (r - l > 1)
    {
        
int k = (l + r) / 2;
        LineTree temp;
        temp.build(l,k);
        head
->lson = temp.head;
        temp.init();
        temp.build(k,r);
        head
->rson = temp.head;
    }
}
void LineTree::insert(int l,int r) // 插入一條線段
{
    
if (l <= head->&& r >= head->j)
        (head
->count)++;
    
else
    {
        LineTree temp;
        
if (l < (head->i+head->j)/2)
        {
            temp.init(head
->lson);
            temp.insert(l,r);
        }
        
if (r > (head->i+head->j)/2)
        {
            temp.init(head
->rson);
            temp.insert(l,r);
        }
    }
    updateM();
    updateLine();
}
void LineTree::del(int l,int r) // 刪除一條線段
{
    
if (l <= head->&& head-><= r)
        (head
->count)--;
    
else
    {
        LineTree temp;
        
if (l < (head->i+head->j)/2)
        {
            temp.init(head
->lson);
            temp.del(l,r);
        }
        
if (r > (head->i+head->j)/2)
        {
            temp.init(head
->rson);
            temp.del(l,r);
        }
    }
    updateM();
    updateLine();
}
int LineTree::GetM() // 測度
{
    
return head->m;
}
int LineTree::GetLine() // 連續段數
{
    
return head->line;
}
int LineTree::GetCov() // 覆蓋線段數
{
    
return head->count;
}
LineTree::
~LineTree()
{
    
this->clear();
}

posted on 2008-08-05 09:24 NicYun 閱讀(4288) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲啪啪91| 欧美在线观看一区| 欧美精品日韩一区| 亚洲人成7777| 日韩午夜在线播放| 欧美体内she精视频| 午夜在线a亚洲v天堂网2018| 亚洲欧美一区二区精品久久久| 国产精品视频99| 久久激情网站| 麻豆成人在线播放| 中文日韩在线视频| 亚洲欧美国产毛片在线| 激情成人在线视频| 亚洲欧洲另类国产综合| 国产精品久久久久久久久久直播| 午夜免费在线观看精品视频| 久久国产视频网| 亚洲美女精品成人在线视频| 亚洲一区二区伦理| 一区精品在线| 一本大道久久a久久精二百| 国产网站欧美日韩免费精品在线观看 | 国产精品成人国产乱一区| 欧美亚洲一区二区在线| 六十路精品视频| 亚洲免费视频一区二区| 久久久久久婷| 亚洲一区免费| 欧美顶级艳妇交换群宴| 欧美一级在线播放| 欧美精品日韩综合在线| 久久精品五月婷婷| 欧美日韩一本到| 欧美成人xxx| 国产欧美一区二区在线观看| 亚洲欧洲一区二区在线播放| 国产日本欧美一区二区| 亚洲欧洲日本在线| 亚洲成色精品| 在线亚洲美日韩| 亚洲精品少妇30p| 国内精品伊人久久久久av影院| 亚洲国产婷婷香蕉久久久久久| 亚洲国产高清自拍| 你懂的亚洲视频| 在线观看亚洲一区| 亚洲欧美日韩成人| 亚洲一区二区黄色| 欧美另类综合| 亚洲第一二三四五区| 国产香蕉久久精品综合网| 一区二区三区四区五区精品| 亚洲精品午夜精品| 浪潮色综合久久天堂| 久热这里只精品99re8久| 国产麻豆一精品一av一免费| 亚洲视频中文| 亚洲一区三区在线观看| 欧美日韩一级黄| 日韩天堂在线观看| 一区二区三区久久久| 蜜桃精品久久久久久久免费影院| 久久亚洲精品中文字幕冲田杏梨| 国产欧美日韩免费| 午夜在线精品偷拍| 久久黄色级2电影| 国产日韩欧美在线| 久久精品视频播放| 久久一区二区三区国产精品| 激情综合网址| 免费人成网站在线观看欧美高清| 蜜臀91精品一区二区三区| 1000部国产精品成人观看| 久久久久久亚洲综合影院红桃| 美乳少妇欧美精品| 亚洲人体一区| 欧美日韩国产成人| 亚洲中午字幕| 久久人人精品| 亚洲人精品午夜| 欧美人妖另类| 亚洲午夜精品久久久久久浪潮 | 国产主播一区二区| 久久久噜噜噜久久狠狠50岁| 欧美黄色一级视频| 亚洲一本大道在线| 国产欧美精品一区二区三区介绍| 久久激情综合| 亚洲欧洲一区| 久久成人免费视频| 亚洲国产激情| 国产精品久久午夜| 久久青青草原一区二区| 日韩网站免费观看| 久久精品亚洲一区二区三区浴池| 亚洲黄色在线| 国产精品久久久久一区二区三区共 | 浪潮色综合久久天堂| 亚洲精品国产无天堂网2021| 国产精品看片你懂得| 久久久久国产精品麻豆ai换脸| 亚洲人体影院| 久久精品国产精品亚洲精品| 亚洲精品久久视频| 国产乱码精品一区二区三区av| 麻豆成人小视频| 亚洲欧美国产日韩中文字幕| 亚洲大胆av| 久久久久国产成人精品亚洲午夜| 亚洲精品久久久久| 国产欧美精品一区| 欧美日韩国产bt| 久久久国产视频91| 亚洲一区二区在线播放| 亚洲高清不卡一区| 久久久欧美精品| 亚洲欧美国产77777| 亚洲日本理论电影| 韩国一区二区三区在线观看| 国产精品久久久久久久电影 | 亚洲在线观看| 亚洲乱码国产乱码精品精天堂 | 亚洲国产经典视频| 久久嫩草精品久久久久| 亚洲欧美精品在线| 一区二区三区成人| 最新成人在线| 亚洲大片av| 精品动漫3d一区二区三区免费| 国产精品美女主播在线观看纯欲| 欧美久久成人| 欧美韩日精品| 欧美大片18| 欧美二区视频| 欧美岛国激情| 欧美韩日视频| 欧美国产日韩a欧美在线观看| 噜噜噜91成人网| 久久综合九色综合欧美狠狠| 久久亚洲国产精品日日av夜夜| 9久re热视频在线精品| 中文高清一区| 亚洲综合社区| 国产日韩精品一区二区| 亚洲欧美另类久久久精品2019| 一本色道久久加勒比精品| 欧美精品色网| 日韩视频免费看| 亚洲午夜精品一区二区三区他趣| 国产精品美女久久久久久免费| 亚洲国产高清视频| 亚洲国产日韩欧美在线99| 亚洲欧美日韩另类| 亚洲欧美日韩在线观看a三区| 亚洲免费网址| 久久久久久久久久久久久女国产乱 | 亚洲一区国产一区| 一区二区三区欧美日韩| 日韩午夜免费视频| 亚洲午夜电影网| 午夜宅男久久久| 久久福利资源站| 欧美成人黑人xx视频免费观看| 亚洲电影在线免费观看| 亚洲精品视频在线| 亚洲欧美激情视频| 久久影院午夜论| 欧美日韩在线播放三区| 国产午夜精品久久久久久免费视 | 免费观看久久久4p| 欧美色欧美亚洲另类二区 | 欧美另类在线观看| 国产精品一区二区三区乱码| 狠狠色伊人亚洲综合成人| 亚洲国产裸拍裸体视频在线观看乱了 | 欧美区国产区| 国产欧美日韩视频一区二区三区| 在线观看欧美激情| 一区二区欧美亚洲| 久久亚洲色图| 日韩视频亚洲视频| 久久99伊人| 欧美日韩视频第一区| 国内外成人免费激情在线视频网站 | 老牛影视一区二区三区| 欧美午夜片在线观看| 亚洲成人在线| 欧美一区免费视频| 亚洲人成艺术| 欧美在线看片| 国产精品家教| 亚洲精品永久免费| 久久性天堂网| 亚洲一区尤物| 欧美日韩三区四区| 亚洲激情电影中文字幕| 久久久精品tv| 亚洲午夜久久久久久久久电影院 | 欧美国产欧美亚洲国产日韩mv天天看完整 |