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

C++之竹

無論是太陽下,還是風(fēng)雨中,都要成長!

常用鏈接

統(tǒng)計(jì)

最新評(píng)論

樹中兩個(gè)結(jié)點(diǎn)的最低公共祖先

<本文的樣例代碼:/Files/qingbizhu/LowestCommonAncestor.zip>
 
這是《劍指Offer——名企面試官精講典型編程題》一書中的面試題50,此題針對(duì)所給條件的不同,將需要截然不同的解題思路和方法。書中給出了針對(duì)此題的3種不同條件的解題,本文所要講解的是對(duì)其第3種條件的一個(gè)改進(jìn)解法。具體的題目及條件如下。
 
【題目】:
      輸入兩個(gè)樹結(jié)點(diǎn),求它們的最低公共祖先。

【補(bǔ)充條件】:

      樹是普通的樹,而且樹中的結(jié)點(diǎn)沒有指向父節(jié)點(diǎn)的指針。

 

針對(duì)上述的題目和條件,書中給出了如下解決方案。

 

【原方案】:

      使用兩個(gè)鏈表,對(duì)樹進(jìn)行兩次遍歷以查找兩個(gè)樹結(jié)點(diǎn),并保持路徑到兩個(gè)鏈表中,從而將問題轉(zhuǎn)化為求兩個(gè)鏈表的最后一個(gè)公共結(jié)點(diǎn)。

 

從該方案中,觀察到兩次樹結(jié)點(diǎn)查找的遍歷中,其中一個(gè)結(jié)點(diǎn)的遍歷過的樹結(jié)點(diǎn)序列將完全覆蓋查找另一結(jié)點(diǎn)時(shí)所遍歷的樹結(jié)點(diǎn)序列。由此入手,本文提出了如下的改進(jìn)解決方案。

【改進(jìn)方案】:

    深度優(yōu)先遍歷樹,并記錄路徑,當(dāng)找到第一個(gè)結(jié)點(diǎn)后,在當(dāng)前基礎(chǔ)上繼續(xù)遍歷搜索第二個(gè)結(jié)點(diǎn),并記錄第一個(gè)結(jié)點(diǎn)路徑的變化程度,直到找到第二個(gè)結(jié)點(diǎn)。最后,根據(jù)棧信息和記錄的結(jié)點(diǎn)路徑變化程度得到最低公共祖先。如圖1,假設(shè)輸入的兩個(gè)樹結(jié)點(diǎn)為DK,樹的根節(jié)點(diǎn)為R,則求DK的最低公共結(jié)點(diǎn)的過程如下表: 

步驟

第一個(gè)結(jié)點(diǎn)

第二個(gè)結(jié)點(diǎn)

路徑變化程度

1

R

2

RA

3

RAF

4

RAFJ

5

RAFG

6

RAFK

K

0(或K

7

RAC

K

1(或A

8

RACE

K

2(或A

9

RACI

K

2(或A

10

RAD

K

D

1(或A

è 得出結(jié)果,最低公共祖先結(jié)點(diǎn)為A

 

從中,可以看到,改進(jìn)后的方案,只需對(duì)樹執(zhí)行一次遍歷。而在輔助空間的需求上, 只需使用一個(gè)棧(外加少量結(jié)點(diǎn)指針變量和1個(gè)表示路徑變化程度的整型變量)。而且,如果采用遞歸的方式實(shí)現(xiàn),該棧所需保存的信息,還可以通過遞歸時(shí)的函數(shù)調(diào)用棧得以保存。

 

【附注】:

  1. 此處,有如下一個(gè)問題:
    假設(shè)待查找公共祖先的兩樹結(jié)點(diǎn),其中一結(jié)點(diǎn)在以另一結(jié)點(diǎn)為根的子樹上(包括兩結(jié)點(diǎn)相同)時(shí),公共祖先的確定規(guī)則——
    “作為子樹根結(jié)點(diǎn)的那個(gè)結(jié)點(diǎn)”還是“子樹根結(jié)點(diǎn)的父節(jié)點(diǎn)”?
    例如:對(duì)上面圖1中的那棵樹,如果待查結(jié)點(diǎn)為根結(jié)點(diǎn)R和結(jié)點(diǎn)F,那么最終的查找結(jié)果是為R呢,還是因?yàn)?/span>R是根結(jié)點(diǎn)無父結(jié)點(diǎn)而得出NULL
    此問題在書中未提及,但查看書中代碼,確認(rèn)是選擇了后者;而在本人的樣例代碼中則采用了前面的觀點(diǎn)。
  2. 在樣例代碼中,對(duì)樹結(jié)點(diǎn)在棧中的存儲(chǔ)方式略有改動(dòng)。
  3. 樣例代碼工程所使用的環(huán)境為 Visual C++ 2010;
    其中:tree.h/cpp為功能代碼文件,TestLowestCommonAncestor.h/cpp為相應(yīng)的UT代碼文件;
    UT采用gtest所編寫,編譯鏈接請(qǐng)根據(jù)gtest在自己本機(jī)的路徑狀況修改gtest_link.props文件中相應(yīng)的鏈接項(xiàng)。

 

posted on 2012-04-05 23:45 青碧竹 閱讀(3099) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 算法相關(guān)

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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页| 欧美日韩亚洲视频一区| 国产精品日日摸夜夜摸av| 国产乱人伦精品一区二区| 黄色成人av| 亚洲黄色三级| 亚洲香蕉在线观看| 久久黄色网页| 亚洲二区视频在线| 亚洲国产日韩一区| 亚洲图片自拍偷拍| 久久综合99re88久久爱| 欧美日韩高清在线播放| 国产一区自拍视频| 99re视频这里只有精品| 久久精品国产v日韩v亚洲 | 欧美在线观看视频一区二区三区| 久久精品一区二区三区四区| 欧美激情精品久久久| 国产精品vvv| 亚洲国产精品久久久久秋霞不卡| 99热这里只有成人精品国产| 欧美在线播放| 亚洲人成在线观看一区二区| 香蕉成人久久| 欧美午夜电影网| 亚洲国产日韩在线一区模特| 亚洲美女精品一区| 一本色道久久综合精品竹菊 | 国产美女精品视频免费观看| 亚洲国产裸拍裸体视频在线观看乱了中文 | 欧美在线日韩在线| 欧美午夜精品久久久久久人妖| 好吊妞这里只有精品| 亚洲伊人第一页| 亚洲国产婷婷综合在线精品 | 欧美国产日韩二区| 狠狠色狠狠色综合日日小说| 午夜激情综合网| 一本色道久久综合狠狠躁的推荐| 久久久午夜精品| 国产一区二区三区日韩| 午夜在线视频观看日韩17c| 亚洲精品久久久久| 欧美成人有码| 亚洲国内自拍| 亚洲第一中文字幕| 久久躁狠狠躁夜夜爽| 国内精品嫩模av私拍在线观看| 亚洲欧美在线另类| 一区二区三区四区五区视频| 欧美日韩精品一区视频| 亚洲精品黄网在线观看| 欧美国产日韩在线| 欧美成人激情视频| 亚洲精品黄网在线观看| 亚洲高清电影| 欧美极品影院| 亚洲亚洲精品在线观看| 亚洲视频播放| 国产午夜久久久久| 噜噜噜在线观看免费视频日韩| 久久国产精品高清| 18成人免费观看视频| 亚洲高清免费视频| 欧美精品首页| 午夜在线观看免费一区| 欧美一区二区三区在线| 黄色在线一区| 亚洲国产一区二区a毛片| 欧美日本国产一区| 午夜免费电影一区在线观看| 欧美在线资源| 亚洲美女毛片| 一区二区三区欧美日韩| 国产日韩欧美视频| 美女999久久久精品视频| 欧美国产精品v| 欧美成ee人免费视频| 亚洲综合第一| 激情久久久久久久| 欧美激情精品久久久久| 欧美色播在线播放| 久久亚洲国产精品一区二区| 欧美成年人视频| 亚洲欧美国产日韩中文字幕| 久久福利视频导航| 一本色道久久综合| 欧美一区二区视频观看视频| 亚洲精品网站在线播放gif| 在线亚洲精品福利网址导航| 久久九九国产精品| 浪潮色综合久久天堂| 亚洲网站在线观看| 欧美一级视频| 99视频精品| 欧美一区二区在线播放| 99re66热这里只有精品3直播| 亚洲一区成人| 亚洲国产高清在线| 在线亚洲欧美视频| 亚洲精品一区二| 欧美一区日本一区韩国一区| 91久久夜色精品国产九色| 亚洲视频一区二区| 伊人夜夜躁av伊人久久| 亚洲午夜三级在线| 亚洲国产美女| 久久狠狠婷婷| 久久国产精品亚洲77777| 欧美日韩mp4| 亚洲国产美女| 亚洲高清中文字幕| 久久国产精品电影| 欧美在线视频免费播放| 欧美日韩免费| 亚洲精品色图| 亚洲国产一区视频| 久久精品国产77777蜜臀| 一区二区欧美精品| 欧美极品一区| 老色批av在线精品| 国产伦精品一区二区三区在线观看 | 欧美国产精品va在线观看| 欧美韩日一区| 1024国产精品| 亚洲精品美女91| 国产精品一区二区久久久久| 亚洲国产成人porn| 在线观看一区| 久久这里只有精品视频首页| 久久天堂av综合合色| 国产精品一区一区| 亚洲天堂av图片| 亚洲欧美日产图| 欧美午夜精品伦理| 亚洲综合社区| 欧美影院成年免费版| 国产精品视频免费观看www| 亚洲午夜免费福利视频| 亚洲性图久久| 在线播放日韩| 欧美自拍偷拍| 狼人天天伊人久久| 亚洲成人自拍视频| 欧美成人首页| 亚洲激情视频在线观看| 99视频热这里只有精品免费| 欧美韩日亚洲| 欧美xx视频| 亚洲最新色图| 午夜视频久久久久久| 好看不卡的中文字幕| 久久久精品一区二区三区| 欧美国产综合| 一本色道久久88亚洲综合88| 国产精品多人| 久久精品国产69国产精品亚洲 | 亚洲免费观看在线观看| 欧美精品一区视频| 99在线精品观看| 久久影院午夜论| 亚洲视频中文| 国内精品嫩模av私拍在线观看| 美女爽到呻吟久久久久| 一本综合精品| 欧美成人精品不卡视频在线观看 | 久久黄色影院| 亚洲国产一区二区a毛片| 午夜亚洲福利在线老司机| 亚洲国产高清一区| 国产精品久久久久久久午夜片 | 久久综合九色综合欧美就去吻| 亚洲人成人99网站| 久久久久.com| 一区二区国产在线观看| 韩国一区电影| 国产精品免费网站在线观看| 米奇777超碰欧美日韩亚洲| 亚洲夜间福利| 欧美在线免费一级片| aa级大片欧美三级| 在线观看中文字幕亚洲| 国产精品高潮呻吟久久av无限| 久久久人成影片一区二区三区观看 | 亚洲永久精品大片| 亚洲国内自拍| 久久精品国产69国产精品亚洲 | 亚洲欧美亚洲| 亚洲精品综合精品自拍| 激情欧美一区二区三区在线观看| 欧美日韩亚洲系列| 欧美风情在线| 免费成人小视频| 久久永久免费|