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

A Za, A Za, Fighting...

堅信:勤能補拙

[zz] 線段樹(1)

好久沒寫過算法了,添一個吧,寫一個線段樹的入門知識,比較大眾化。

上次在湖大,其中的一道題數據很強,我試了好多種優化都TLE,相信只能用線段樹才能過。回來之后暗暗又學了一次線段樹,想想好像是第三次學了,像網絡流一樣每學一次都有新的體會。

把問題簡化一下:

在自然數,且所有的數不大于30000的范圍內討論一個問題:現在已知n條線段,把端點依次輸入告訴你,然后有m個詢問,每個詢問輸入一個點,要求這個點在多少條線段上出現過;

最基本的解法當然就是讀一個點,就把所有線段比一下,看看在不在線段中;

每次詢問都要把n條線段查一次,那么m次詢問,就要運算m*n次,復雜度就是O(m*n)

這道題m和n都是30000,那么計算量達到了10^9;而計算機1秒的計算量大約是10^8的數量級,所以這種方法無論怎么優化都是超時

-----

因為n條線段是固定的,所以某種程度上說每次都把n條線段查一遍有大量的重復和浪費;

線段樹就是可以解決這類問題的數據結構

舉例說明:已知線段[2,5] [4,6] [0,7];求點2,4,7分別出現了多少次

在[0,7]區間上建立一棵滿二叉樹:(為了和已知線段區別,用【】表示線段樹中的線段)

                                               【0,7】
                               /                                            \
                     【0,3】                                           【4,7】
                  /               \                                    /                \
       【0,1】             【2,3】                     【4,5】               【6,7】
         /      \                 /      \                     /      \                   /      \
【0,0】 【1,1】    【2,2】 【3,3】   【4,4】  【5,5】       【6,6】 【7,7】

每個節點用結構體:

struct line
{
      int left,right;//左端點、右端點
      int n;//記錄這條線段出現了多少次,默認為0
}a[16];

和堆類似,滿二叉樹的性質決定a[i]的左兒子是a[2*i]、右兒子是a[2*i+1];

然后對于已知的線段依次進行插入操作:

從樹根開始調用遞歸函數insert

void insert(int s,int t,int step)//要插入的線段的左端點和右端點、以及當前線段樹中的某條線段
{
      if (s==a[step].left && t==a[step].right)
      {
            a[step].n++;//插入的線段匹配則此條線段的記錄+1
            return;//插入結束返回
      }
      if (a[step].left==a[step].right)   return;//當前線段樹的線段沒有兒子,插入結束返回
      int mid=(a[step].left+a[step].right)/2;
      if (mid>=t)    insert(s,t,step*2);//如果中點在t的右邊,則應該插入到左兒子
      else if (mid<s)    insert(s,t,step*2+1);//如果中點在s的左邊,則應該插入到右兒子
      else//否則,中點一定在s和t之間,把待插線段分成兩半分別插到左右兒子里面
      {
            insert(s,mid,step*2);
            insert(mid+1,t,step*2+1);
      }
}

三條已知線段插入過程:

[2,5]

--[2,5]與【0,7】比較,分成兩部分:[2,3]插到左兒子【0,3】,[4,5]插到右兒子【4,7】

--[2,3]與【0,3】比較,插到右兒子【2,3】;[4,5]和【4,7】比較,插到左兒子【4,5】

--[2,3]與【2,3】匹配,【2,3】記錄+1;[4,5]與【4,5】匹配,【4,5】記錄+1

[4,6]

--[4,6]與【0,7】比較,插到右兒子【4,7】

--[4,6]與【4,7】比較,分成兩部分,[4,5]插到左兒子【4,5】;[6,6]插到右兒子【6,7】

--[4,5]與【4,5】匹配,【4,5】記錄+1;[6,6]與【6,7】比較,插到左兒子【6,6】

--[6,6]與【6,6】匹配,【6,6】記錄+1

[0,7]

--[0,7]與【0,7】匹配,【0,7】記錄+1

插入過程結束,線段樹上的記錄如下(紅色數字為每條線段的記錄n):

                                                 【0,7】
                                                      1
                               /                                              \
                     【0,3】                                             【4,7】
                         0                                                     0
                 /                 \                                     /                 \
       【0,1】                 【2,3】                【4,5】                  【6,7】
            0                           1                          2                         0
          /    \                      /      \                     /     \                    /      \
【0,0】 【1,1】       【2,2】   【3,3】       【4,4】 【5,5】     【6,6】  【7,7】
     0            0            0            0            0            0           1           0

詢問操作和插入操作類似,也是遞歸過程,略

2——依次把【0,7】 【0,3】 【2,3】 【2,2】的記錄n加起來,結果為2

4——依次把【0,7】 【4,7】 【4,5】 【4,4】的記錄n加起來,結果為3

7——依次把【0,7】 【4,7】 【6,7】 【7,7】的記錄n加起來,結果為1

不管是插入操作還是查詢操作,每次操作的執行次數僅為樹的深度——logN

建樹有n次插入操作,n*logN,一次查詢要logN,m次就是m*logN;總共復雜度O(n+m)*logN,這道題N不超過30000,logN約等于14,所以計算量在10^5~10^6之間,比普通方法快了1000倍;

這道題是線段樹最基本的操作,只用到了插入和查找;刪除操作和插入類似,擴展功能的還有測度、連續段數等等,在N數據范圍很大的時候,依然可以用離散化的方法建樹。

湖大的那道題目繞了個小彎子,alpc12有詳細的題目和解題報告,有興趣的話可以看看http://www.shnenglu.com/sicheng/archive/2008/01/09/40791.html

線段樹的經典題目就是poj1177的picturehttp://acm.pku.edu.cn/JudgeOnline/problem?id=1177

posted on 2010-09-15 18:46 simplyzhao 閱讀(257) 評論(0)  編輯 收藏 引用 所屬分類: G_其他

導航

<2010年7月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

統計

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            免费亚洲电影| 欧美国产先锋| 亚洲国产精品va在线看黑人 | 黑人中文字幕一区二区三区| 国产精品美女久久久久久久| 国产精品久久久久9999高清| 国产精品久久999| 国产美女精品人人做人人爽| 国产偷久久久精品专区| 久久久7777| 欧美福利一区| 欧美天堂亚洲电影院在线观看| 国产精品国产三级国产专区53| 国产三级精品三级| 亚洲美女在线看| 午夜精品久久一牛影视| 久久精品国产精品 | 国产精品久久久久久久久久尿| 国产精品一页| 亚洲国产高清aⅴ视频| 亚洲色在线视频| 久久久久国产一区二区| 欧美日韩高清在线| 久久av红桃一区二区小说| 噜噜噜在线观看免费视频日韩| 欧美日韩一区二区免费在线观看| 国产精品系列在线| 91久久精品美女高潮| 亚洲欧美在线另类| 欧美激情一区二区在线| 亚洲已满18点击进入久久| 久久欧美中文字幕| 国产精品视频内| 亚洲国产欧美久久| 国产精品网站在线播放| 91久久国产综合久久| 久久激情五月婷婷| 99re这里只有精品6| 久久永久免费| 国产一区二区三区丝袜| 亚洲欧美精品在线| 日韩视频一区二区在线观看 | 欧美国产一区在线| 亚洲男女自偷自拍| 欧美日韩一区二区在线观看| 亚洲高清久久久| 久久久www免费人成黑人精品 | 国产精品theporn| 91久久精品日日躁夜夜躁欧美| 久久精品一本久久99精品| 中文av一区二区| 欧美日韩一区高清| 亚洲精品在线二区| 欧美激情视频一区二区三区免费| 亚洲欧美日韩直播| 欧美日韩在线观看视频| 欧美激情第五页| 中日韩美女免费视频网址在线观看 | 久久精品人人爽| 国产精品网站在线| 久久av老司机精品网站导航 | 久久尤物视频| 伊人成年综合电影网| 久久久综合网站| 久久国产欧美| 国产最新精品精品你懂的| 久久精品国产亚洲精品| 亚洲欧美日韩国产一区二区三区| 欧美日韩国产页| 亚洲一区观看| 亚洲免费视频一区二区| 国产日韩在线亚洲字幕中文| 久久亚洲国产精品一区二区| 亚洲高清视频在线| 欧美福利小视频| 一本色道久久88亚洲综合88| 日韩视频专区| 国产精品免费看| 久久激情久久| 久久一区二区三区国产精品| 亚洲精品男同| 亚洲视频一区在线观看| 国产精品久久久久久久久婷婷 | 国产欧美日韩在线 | 亚洲女优在线| 亚洲欧美日本视频在线观看| 国产精品激情电影| 狂野欧美一区| 欧美日韩精品免费| 欧美在线观看视频一区二区三区| 久久激情综合网| 亚洲精选成人| 亚洲欧美日韩一区二区| 亚洲国产日韩欧美在线图片| 99精品国产热久久91蜜凸| 国产精品一卡二| 欧美国产在线电影| 国产精品永久免费| 亚洲高清视频的网址| 国产精品自拍小视频| 欧美激情精品久久久久久蜜臀| 欧美日韩大片一区二区三区| 久久久www免费人成黑人精品 | 亚洲黄色大片| 正在播放亚洲一区| 影音先锋另类| 亚洲网站啪啪| 亚洲人成在线观看网站高清| 亚洲永久视频| 日韩一区二区久久| 久久久久综合一区二区三区| 99re6热只有精品免费观看 | 亚洲午夜免费视频| 亚洲精品1区| 久久精品二区| 欧美伊人久久久久久午夜久久久久 | 国产精品在线看| 亚洲精品免费看| 黄色日韩精品| 午夜精品www| 亚洲欧美在线免费观看| 欧美激情成人在线| 欧美激情第9页| 久久综合伊人77777麻豆| 欧美日韩精品在线观看| 欧美成人黑人xx视频免费观看| 国产欧美日韩综合一区在线观看 | 99香蕉国产精品偷在线观看| 欧美专区第一页| 久久激情久久| 国产伦精品一区二区三区高清版| 夜夜爽www精品| 一区二区三区 在线观看视频 | 伊人精品成人久久综合软件| 亚洲一区三区视频在线观看 | 国产亚洲欧美日韩日本| 一本久久a久久精品亚洲| 一本色道**综合亚洲精品蜜桃冫| 免费欧美在线| 亚洲国产一区二区三区青草影视 | 一本色道久久综合亚洲二区三区| 两个人的视频www国产精品| 免费不卡中文字幕视频| 激情六月婷婷久久| 久久久久久久久久久一区| 久久久xxx| 亚洲国产成人91精品| 老司机免费视频一区二区| 亚洲国产另类 国产精品国产免费| 亚洲高清不卡在线| 欧美好骚综合网| 一区二区三欧美| 一本色道久久精品| 国产精品久久久久久久久婷婷| 亚洲午夜女主播在线直播| 久久国产精品网站| 黄色国产精品| 欧美区二区三区| 亚洲天堂av图片| 久久成人一区| 亚洲黑丝在线| 欧美日韩国产三区| 亚洲在线免费| 免播放器亚洲一区| 亚洲线精品一区二区三区八戒| 国产精品青草综合久久久久99 | 狠狠色伊人亚洲综合网站色| 久久免费黄色| 亚洲精品一区二区网址| 欧美亚洲综合另类| 亚洲国产黄色| 国产精品嫩草影院一区二区| 久久精品最新地址| 99精品福利视频| 久久综合999| 一区二区三区蜜桃网| 国产亚洲美州欧州综合国| 午夜视频在线观看一区| 亚洲第一福利视频| 欧美一区二区免费| 欧美激情亚洲精品| 久久中文字幕导航| 国产日韩精品一区二区三区| 久久久噜噜噜久久久| 999亚洲国产精| 美女视频黄a大片欧美| 欧美性猛交xxxx乱大交退制版| 欧美一区二区三区婷婷月色 | 欧美亚洲三区| 亚洲国产高清高潮精品美女| 亚洲专区一二三| 亚洲第一主播视频| 国产精品一页| 国产精品国产三级国产a| 欧美大片va欧美在线播放| 久久aⅴ国产欧美74aaa| 在线视频日韩| 亚洲九九九在线观看| 亚洲电影免费观看高清完整版在线观看| 亚洲视频在线观看网站|