• <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>
            隨筆-80  評論-24  文章-0  trackbacks-0
            題目要求比較簡單,寫一程序求一棵二叉樹中相距最遠的兩個節(jié)點之間的距離。
            其實第一眼就能相當用遞歸是最簡單也是最直觀的:
            以當前節(jié)點v為根的子樹中兩節(jié)點的最遠距離有三種情況:
            1、距離最遠的兩個節(jié)點均在v的左子樹
            2、距離最遠的兩個節(jié)點均在v的右子樹
            3、距離最遠的兩個節(jié)點一個在左子樹一個在右子樹(或者v就是其中一個節(jié)點)
            對于第三種情況,只需要計算左子樹的高度和右子樹的高度,然后相加即可;
            對于第一種和第二種情況,則需要知道左子樹的最遠距離,以及右子樹的最遠距離;
            因此數(shù)據(jù)結構如下:

            1 struct Node {
            2   int value;
            3   int left_height;
            4   int right_height;
            5   Node *left;
            6   Node *right;
            7 };

            其中l(wèi)eft_height和right_height記錄左右子樹的高度;
            函數(shù)實現(xiàn)如下:

             1 #define max(a, b) ((a) > (b) ? (a) : (b))
             2 
             3 int find_max_len(Node *t) {
             4   if (t == NULL) {
             5     return 0;
             6   }
             7 
             8   int left_max_len = find_max_len(t->left);
             9   int right_max_len = find_max_len(t->right);
            10 
            11   if (t->left) {
            12     t->left_height = 1 + max(t->left->left_height, t->left->right_height);
            13   }
            14   if (t->right) {
            15     t->right_height = 1 + max(t->right->left_height, t->right->right_height);
            16   }
            17 
            18   int max_len = max(left_max_len, right_max_len);
            19   max_len = max(max_len, t->left_height + t->right_height);
            20 
            21   return max_len;
            22 }

            函數(shù)有一個返回值,用于返回以t為根的樹的最遠距離。
            posted on 2012-09-03 17:12 myjfm 閱讀(2301) 評論(0)  編輯 收藏 引用 所屬分類: 算法基礎
            亚洲AV日韩精品久久久久| 久久综合九色综合精品| 久久久久亚洲精品中文字幕 | 51久久夜色精品国产| 久久精品综合一区二区三区| 性高湖久久久久久久久AAAAA| 色婷婷综合久久久久中文| 久久青青草原精品影院| 亚洲精品国精品久久99热| 久久精品国产99久久久 | 亚洲国产另类久久久精品| 97久久精品无码一区二区| 女人高潮久久久叫人喷水| 国产精品久久精品| 亚洲精品tv久久久久久久久久| 国产精品美女久久久m| 麻豆av久久av盛宴av| 国产精品内射久久久久欢欢| 亚洲精品蜜桃久久久久久| 久久精品中文字幕有码| 久久国产色AV免费观看| 97精品依人久久久大香线蕉97| 久久精品无码一区二区日韩AV| 99久久er这里只有精品18| 精品多毛少妇人妻AV免费久久 | 久久黄视频| 99久久精品日本一区二区免费| 久久99精品久久久大学生| 久久青青草原精品国产不卡| 7国产欧美日韩综合天堂中文久久久久 | 国产精品伦理久久久久久| www性久久久com| 久久超碰97人人做人人爱| 久久99精品久久久久婷婷| 色欲av伊人久久大香线蕉影院| 99久久做夜夜爱天天做精品| 伊人久久大香线蕉成人| 午夜精品久久久内射近拍高清 | 国产精品欧美久久久久天天影视 | 人妻无码αv中文字幕久久琪琪布| 99久久免费国产精品特黄|