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

A Za, A Za, Fighting...

堅(jiān)信:勤能補(bǔ)拙

[zz] 線段樹(1)

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

上次在湖大,其中的一道題數(shù)據(jù)很強(qiáng),我試了好多種優(yōu)化都TLE,相信只能用線段樹才能過?;貋碇蟀蛋涤謱W(xué)了一次線段樹,想想好像是第三次學(xué)了,像網(wǎng)絡(luò)流一樣每學(xué)一次都有新的體會(huì)。

把問題簡化一下:

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

最基本的解法當(dāng)然就是讀一個(gè)點(diǎn),就把所有線段比一下,看看在不在線段中;

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

這道題m和n都是30000,那么計(jì)算量達(dá)到了10^9;而計(jì)算機(jī)1秒的計(jì)算量大約是10^8的數(shù)量級(jí),所以這種方法無論怎么優(yōu)化都是超時(shí)

-----

因?yàn)閚條線段是固定的,所以某種程度上說每次都把n條線段查一遍有大量的重復(fù)和浪費(fèi);

線段樹就是可以解決這類問題的數(shù)據(jù)結(jié)構(gòu)

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

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

                                               【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】

每個(gè)節(jié)點(diǎn)用結(jié)構(gòu)體:

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

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

然后對(duì)于已知的線段依次進(jìn)行插入操作:

從樹根開始調(diào)用遞歸函數(shù)insert

void insert(int s,int t,int step)//要插入的線段的左端點(diǎn)和右端點(diǎn)、以及當(dāng)前線段樹中的某條線段
{
      if (s==a[step].left && t==a[step].right)
      {
            a[step].n++;//插入的線段匹配則此條線段的記錄+1
            return;//插入結(jié)束返回
      }
      if (a[step].left==a[step].right)   return;//當(dāng)前線段樹的線段沒有兒子,插入結(jié)束返回
      int mid=(a[step].left+a[step].right)/2;
      if (mid>=t)    insert(s,t,step*2);//如果中點(diǎn)在t的右邊,則應(yīng)該插入到左兒子
      else if (mid<s)    insert(s,t,step*2+1);//如果中點(diǎn)在s的左邊,則應(yīng)該插入到右兒子
      else//否則,中點(diǎn)一定在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

插入過程結(jié)束,線段樹上的記錄如下(紅色數(shù)字為每條線段的記錄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加起來,結(jié)果為2

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

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

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

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

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

湖大的那道題目繞了個(gè)小彎子,alpc12有詳細(xì)的題目和解題報(bào)告,有興趣的話可以看看http://m.shnenglu.com/sicheng/archive/2008/01/09/40791.html

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

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

導(dǎo)航

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

統(tǒng)計(jì)

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

搜索

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美一区三区三区高中清蜜桃| 亚洲男女自偷自拍图片另类| 欧美性猛交xxxx乱大交蜜桃| 亚洲欧美bt| 亚洲一区二区精品在线观看| 亚洲国产精品视频| 午夜亚洲视频| 欧美亚洲一级片| 久久蜜桃精品| 嫩草成人www欧美| 欧美成人伊人久久综合网| 免费亚洲一区| 亚洲精品乱码久久久久久日本蜜臀 | 国产精品视频网| 国产精品网站在线观看| 国产精品家庭影院| 国模吧视频一区| 亚洲国产欧美一区| 亚洲欧美激情一区二区| 麻豆精品视频在线| 可以看av的网站久久看| 欧美日本三级| 国产色爱av资源综合区| 在线国产精品播放| 亚洲视频香蕉人妖| 免费观看成人www动漫视频| 亚洲激情二区| 久久精品国产第一区二区三区| 久久蜜桃香蕉精品一区二区三区| 久久在线免费观看视频| 欧美激情一区二区三区蜜桃视频| 欧美日韩国产精品一卡| 国产麻豆视频精品| 在线亚洲国产精品网站| 欧美一区二区三区在线看| 久久er精品视频| 亚洲国产日韩一区二区| 亚洲无玛一区| 欧美福利电影在线观看| 国产精品一区三区| 亚洲午夜视频| 亚洲国内高清视频| 久久精品国产在热久久 | 欧美激情精品久久久久久大尺度| 欧美精品亚洲精品| 国内精品视频一区| 亚洲永久在线观看| 亚洲激情婷婷| 欧美 日韩 国产在线| 国产欧美日韩免费| 亚洲天堂网站在线观看视频| 欧美一二三区精品| 亚洲精品中文字| 老司机免费视频一区二区| 欧美色网在线| 亚洲欧洲日本在线| 久久精品人人做人人综合| 欧美日韩视频| 91久久国产综合久久蜜月精品 | 久久三级视频| 国产美女精品免费电影| 一区二区免费在线播放| 免费观看日韩av| 午夜精品久久久久久久男人的天堂| 久久综合久久综合久久综合| 欧美福利一区| 亚洲精品黄网在线观看| 另类天堂视频在线观看| 午夜精品久久久久久久久久久久| 欧美精品亚洲二区| 夜夜嗨av色一区二区不卡| 欧美国产日韩一区二区| 久久久亚洲精品一区二区三区 | 亚洲福利一区| 免费日韩精品中文字幕视频在线| 欧美亚洲免费在线| 国产视频久久久久| 麻豆国产精品va在线观看不卡| 欧美一区二区在线免费观看| 欧美日韩亚洲系列| 亚洲一区二区三区在线播放| 欧美激情一区三区| 欧美成人乱码一区二区三区| 国产在线欧美日韩| 久久久精品国产一区二区三区| 亚洲一区二区伦理| 国产视频一区三区| 麻豆久久久9性大片| 久久精品视频一| 1769国内精品视频在线播放| 久久精品视频网| 久久网站热最新地址| 黄色成人在线网址| 亚洲高清视频一区二区| 欧美国产精品久久| 亚洲综合视频网| 国产乱码精品一区二区三区五月婷| 亚洲国产福利在线| 欧美成人福利视频| 亚洲素人一区二区| 亚洲欧美变态国产另类| 国产一区二区三区四区三区四 | 宅男噜噜噜66一区二区66| 欧美日韩亚洲一区三区| 午夜精品久久99蜜桃的功能介绍| 亚洲无毛电影| 黑人巨大精品欧美一区二区小视频| 久久综合九色99| 欧美激情第二页| 欧美一区二区三区婷婷月色 | 久久一区中文字幕| 一区二区三区欧美日韩| 亚洲欧美一区二区激情| 国内成+人亚洲| 亚洲欧洲另类| 国产一区二区精品久久| 开元免费观看欧美电视剧网站| 老司机成人在线视频| 艳女tv在线观看国产一区| 亚洲一区欧美二区| 国产亚洲一区二区精品| 欧美高清自拍一区| 国产亚洲欧美aaaa| 99国产精品| 亚洲国产cao| 亚洲在线观看免费| 一区二区高清| 欧美va亚洲va日韩∨a综合色| 亚洲一区精品电影| 欧美激情国产精品| 久久精品免费| 欧美特黄一区| 亚洲激情电影中文字幕| 国产一级一区二区| 一区二区激情小说| 一区二区三区国产在线| 久久久久青草大香线综合精品| 亚洲精品少妇网址| 免费成人高清视频| 老鸭窝毛片一区二区三区| 国产精品海角社区在线观看| 久久精品国产亚洲一区二区三区| 欧美精品麻豆| 亚洲二区视频在线| 1024精品一区二区三区| 宅男噜噜噜66一区二区| 午夜久久福利| 欧美一级理论性理论a| 欧美日韩日日夜夜| 亚洲精品日韩欧美| 亚洲免费福利视频| 欧美人在线视频| 日韩亚洲精品在线| 亚洲精华国产欧美| 在线观看视频一区二区| 亚洲视频国产视频| 亚洲综合色网站| 欧美日韩免费在线观看| 亚洲国产精品久久人人爱蜜臀| 国模吧视频一区| 欧美一级在线播放| 久久婷婷亚洲| 在线成人激情黄色| 在线不卡欧美| 久久精品中文字幕一区二区三区 | 亚洲欧洲一区二区在线播放| 亚洲免费小视频| 亚洲欧美视频在线| 国产一区日韩一区| 狼人社综合社区| 亚洲精品一区二区三区婷婷月| 99国产精品久久久久久久成人热| 久久综合国产精品| 亚洲三级网站| 亚洲欧美成人在线| 国产自产2019最新不卡| 久久精品国产综合| 欧美激情视频网站| 亚洲自拍偷拍视频| 黄色另类av| 欧美日韩在线视频一区二区| 亚洲精品久久久久久下一站| 中文一区字幕| 久久色在线观看| 在线视频精品| 国产区二精品视| 免费av成人在线| 亚洲永久网站| 最新成人在线| 欧美主播一区二区三区| 国内精品久久久久久久97牛牛| 久久天天躁夜夜躁狠狠躁2022| 亚洲黑丝在线| 久久全国免费视频| 亚洲专区在线视频| 最新成人在线| 国产亚洲人成a一在线v站 | 在线 亚洲欧美在线综合一区| 欧美**人妖| 久久国产精品一区二区|