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

每天早晨叫醒你的不是鬧鐘,而是夢想

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  62 Posts :: 0 Stories :: 5 Comments :: 0 Trackbacks

常用鏈接

留言簿(1)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

題目:二叉樹的結點定義如下:

struct TreeNode

{

        int m_nValue;

        TreeNode* m_pLeft;

        TreeNode* m_pRight;

};

輸入兩棵二叉樹AB,判斷樹B是不是A的子結構。

例如,下圖中的兩棵樹AB,由于A中有一部分子樹的結構和B是一樣的,因此B就是A的子結構。

                 1                                                   8
               /    \                                               /    \
              8    7                                             9    2
            /    \
           9    2
                /  \
               4  7

分析:這是2010年微軟校園招聘時的一道題目。二叉樹一直是微軟面試題中經常出現的數據結構。對微軟有興趣的讀者一定要重點關注二叉樹。

                回到這個題目的本身。要查找樹A中是否存在和樹B結構一樣的子樹,我們可以分為兩步:第一步在樹A中找到和B的根結點的值一樣的結點N,第二步再判斷樹A中以N為根結點的子樹是不是包括和樹B一樣的結構。

                第一步在樹A中查找與根結點的值一樣的結點。這實際上就是樹的遍歷。對二叉樹這種數據結構熟悉的讀者自然知道我們可以用遞歸的方法去遍歷,也可以用循環的方法去遍歷。由于遞歸的代碼實現比較簡潔,面試時如果沒有特別要求,我們通常都會采用遞歸的方式。下面是參考代碼:

bool HasSubtree(TreeNode* pTreeHead1, TreeNode* pTreeHead2)

{

        if((pTreeHead1 == NULL && pTreeHead2 != NULL) ||

                (pTreeHead1 != NULL && pTreeHead2 == NULL))

                return false;

 

        if(pTreeHead1 == NULL && pTreeHead2 == NULL)

                return true;

 

        return HasSubtreeCore(pTreeHead1, pTreeHead2);

}

bool HasSubtreeCore(TreeNode* pTreeHead1, TreeNode* pTreeHead2)

{

        bool result = false;

        if(pTreeHead1->m_nValue == pTreeHead2->m_nValue)

        {

                result = DoesTree1HaveAllNodesOfTree2(pTreeHead1, pTreeHead2);

        }

 

        if(!result && pTreeHead1->m_pLeft != NULL)

                result = HasSubtreeCore(pTreeHead1->m_pLeft, pTreeHead2);

 

        if(!result && pTreeHead1->m_pRight != NULL)

                result = HasSubtreeCore(pTreeHead1->m_pRight, pTreeHead2);

 

        return result;

}

在上述代碼中,我們遞歸調用hasSubtreeCore遍歷二叉樹A。如果發現某一結點的值和樹B的頭結點的值相同,則調用DoesTree1HaveAllNodeOfTree2,做第二步判斷。

在面試的時候,我們一定要注意邊界條件的檢查,即檢查空指針。當樹A或樹B為空的時候,定義相應的輸出。如果沒有檢查并做相應的處理,程序非常容易崩潰,這是面試時非常忌諱的事情。由于沒有必要在每一次遞歸中做邊界檢查(每一次遞歸都做檢查,增加了不必要的時間開銷),上述代碼只在HasSubtree中作了邊界檢查后,在HasSubtreeCore中作遞歸遍歷。

接下來考慮第二步,判斷以樹A中以N為根結點的子樹是不是和樹B具有相同的結構。同樣,我們也可以用遞歸的思路來考慮:如果結點N的值和樹B的根結點不相同,則以N為根結點的子樹和樹B肯定不具有相同的結點;如果他們的值相同,則遞歸地判斷他們的各自的左右結點的值是不是相同。遞歸的終止條件是我們到達了樹A或者樹B的葉結點。參考代碼如下:

bool DoesTree1HaveAllNodesOfTree2(TreeNode* pTreeHead1, TreeNode* pTreeHead2)

{

        if(pTreeHead2 == NULL)

                return true;

 

        if(pTreeHead1 == NULL)

                return false;

 

        if(pTreeHead1->m_nValue != pTreeHead2->m_nValue)

                return false;

 

        return DoesTree1HaveAllNodesOfTree2(pTreeHead1->m_pLeft, pTreeHead2->m_pLeft) &&

                DoesTree1HaveAllNodesOfTree2(pTreeHead1->m_pRight, pTreeHead2->m_pRight);

}

 

  博主何海濤對本博客文章享有版權。網絡轉載請注明出處http://zhedahht.blog.163.com/

posted on 2011-04-29 14:03 沛沛 閱讀(397) 評論(0)  編輯 收藏 引用 所屬分類: 數據結構/算法
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久国产欧美| 亚洲免费观看高清完整版在线观看| 欧美一区二区三区久久精品| 久久精品30| 日韩视频免费在线观看| 欧美激情国产日韩精品一区18| 国产精品成人国产乱一区| 狠狠色狠色综合曰曰| 亚洲一区二区三区四区中文 | 国产精品第一区| 亚洲性视频网址| 午夜一级久久| 欧美日韩亚洲天堂| 亚洲国产精品成人综合色在线婷婷 | 亚洲伊人久久综合| 欧美成人在线影院| 在线播放精品| 久久久久成人精品免费播放动漫| 一区二区三欧美| 欧美劲爆第一页| 亚洲国产成人久久综合一区| 91久久国产精品91久久性色| 久久精品国产亚洲一区二区三区| 久久久久国产精品www| 国产伦精品一区| 亚洲欧美综合网| 亚洲综合成人婷婷小说| 国产精品久久久久一区| 亚洲一区二区三区久久| 香蕉久久夜色精品国产使用方法| 国内自拍视频一区二区三区| 亚洲国产日韩欧美在线图片| 女人香蕉久久**毛片精品| 一区二区三区在线不卡| 久久午夜激情| 毛片精品免费在线观看| 亚洲日本电影| 日韩视频精品在线观看| 精品二区视频| 亚洲综合精品一区二区| 亚洲精品欧美一区二区三区| 欧美亚洲一区二区在线| 精品va天堂亚洲国产| 一区二区三区欧美在线| 亚洲日本中文字幕| 久久精品99国产精品日本| 亚洲视频在线观看网站| 亚洲欧美日韩一区在线| 精品91在线| 午夜国产欧美理论在线播放| 在线亚洲欧美专区二区| 午夜精品美女久久久久av福利| 亚洲三级国产| 免费不卡欧美自拍视频| 久久综合99re88久久爱| 国产日韩欧美日韩大片| 欧美激情精品久久久久久大尺度| 欧美精品久久久久久久久久| 久久综合九色综合欧美就去吻| 国产精品一区二区你懂得| 中日韩美女免费视频网站在线观看| 国产精品一二一区| 中日韩美女免费视频网址在线观看| 亚洲精选大片| 欧美在线观看天堂一区二区三区| 亚洲欧洲精品一区二区三区不卡 | 欧美一区二区在线| 国产精品高潮呻吟久久av无限| 亚洲精品免费一二三区| 国产亚洲福利一区| 亚洲精品欧美激情| 好男人免费精品视频| 亚洲欧美久久久| 性欧美1819sex性高清| 欧美成人午夜视频| 亚洲激情啪啪| 一本大道久久精品懂色aⅴ | 亚洲人成亚洲人成在线观看| 亚洲高清不卡| 欧美黄色影院| 在线视频亚洲| 久久久99国产精品免费| 伊人一区二区三区久久精品| 毛片一区二区三区| 99精品欧美一区二区三区综合在线| 一区二区三区在线视频播放| 久久九九免费| 久久久夜色精品亚洲| 欧美午夜精品理论片a级大开眼界 欧美午夜精品理论片a级按摩 | 欧美欧美天天天天操| 久久久久高清| 亚洲片在线资源| 国产精品久久9| 欧美专区亚洲专区| 亚洲国产91精品在线观看| 一区二区视频欧美| 欧美日韩国产在线一区| 欧美18av| 亚洲第一视频| 久久亚洲国产成人| 噜噜噜91成人网| 国产日韩欧美91| 久久这里只有| 欧美国产三级| 欧美一区二区三区在线观看视频| 一区精品在线播放| 国产精品高清在线观看| 久久精品国产亚洲精品 | 久久疯狂做爰流白浆xx| 国产精品日日摸夜夜添夜夜av| 亚洲人午夜精品免费| 欧美在线一级视频| 亚洲精品久久久久久一区二区| 国产精品久久久久婷婷| 老色鬼精品视频在线观看播放| 一区二区国产精品| 欧美激情国产日韩精品一区18| 久久都是精品| 亚洲综合色丁香婷婷六月图片| 国产精品高潮粉嫩av| 你懂的国产精品永久在线| 欧美在线视频日韩| 午夜激情久久久| 一区二区91| 日韩视频在线观看免费| 欧美激情麻豆| 久久婷婷蜜乳一本欲蜜臀| 羞羞漫画18久久大片| 亚洲视频你懂的| 亚洲精品久久久一区二区三区| 国内在线观看一区二区三区 | 欧美va天堂在线| 久久国产日韩| 欧美一区二区日韩| 亚洲欧美日韩中文视频| 在线视频一区观看| 一本色道88久久加勒比精品| 亚洲精品一区二区三区福利| 91久久久久| 亚洲精品永久免费| 亚洲激情女人| 亚洲精品专区| 日韩西西人体444www| 亚洲美女色禁图| 亚洲美女毛片| 亚洲视频精选在线| 亚洲一本视频| 亚洲国产激情| 亚洲日本va午夜在线电影| 亚洲国产天堂网精品网站| 亚洲黄色有码视频| 亚洲精品久久久久久下一站 | 久久激五月天综合精品| 久久国产色av| 久久只精品国产| 欧美日韩国产黄| 国产精品第一区| 国内精品久久久久久久97牛牛| 欧美激情网友自拍| 欧美日韩三级一区二区| 欧美性事在线| 国产一区二区三区黄视频| 韩国三级在线一区| 日韩天堂在线视频| 黄色国产精品一区二区三区| 精东粉嫩av免费一区二区三区| 曰本成人黄色| 一本色道久久加勒比88综合| 亚洲午夜视频在线| 久久米奇亚洲| 日韩一区二区电影网| 午夜精品久久久久久久久久久久 | 国产精品vip| 黄网站色欧美视频| 99精品视频免费观看| 午夜激情久久久| 欧美高清不卡在线| 免费成人在线视频网站| 久久午夜精品一区二区| 亚洲国产另类 国产精品国产免费| aa亚洲婷婷| 久久精品一区二区三区中文字幕| 男同欧美伦乱| 国产性猛交xxxx免费看久久| 亚洲国产一区视频| 亚洲国产日韩欧美综合久久| 亚洲一区二区三区高清不卡| 久久漫画官网| 中日韩男男gay无套| 久久午夜电影网| 国产精品欧美久久久久无广告| 亚洲国产精品www| 久久精品一区二区国产| 亚洲精品一区二区在线观看| 欧美一区二区精品| 欧美日韩在线不卡| 亚洲国产裸拍裸体视频在线观看乱了中文 | 欧美波霸影院| 亚洲永久网站| 欧美色中文字幕|