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

            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ù)實(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ù)有一個(gè)返回值,用于返回以t為根的樹的最遠(yuǎn)距離。
            posted on 2012-09-03 17:12 myjfm 閱讀(2301) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 算法基礎(chǔ)
            国产农村妇女毛片精品久久| 日本高清无卡码一区二区久久| 国产呻吟久久久久久久92| 99精品伊人久久久大香线蕉| 久久99精品久久久久久9蜜桃| 久久露脸国产精品| 精品久久久一二三区| 五月丁香综合激情六月久久| 久久福利青草精品资源站| 久久AAAA片一区二区| 久久久久久曰本AV免费免费| 久久香蕉超碰97国产精品| 人人狠狠综合久久亚洲88| 国产99久久久国产精品小说| A狠狠久久蜜臀婷色中文网| 久久精品国产一区二区| 人妻少妇久久中文字幕一区二区| 99re久久精品国产首页2020| 久久人搡人人玩人妻精品首页| 久久中文字幕人妻丝袜| 久久99精品国产99久久6男男| 人人狠狠综合久久亚洲高清| 国内精品久久国产大陆| 久久精品一区二区三区AV| 国产成人久久777777| 久久人妻少妇嫩草AV无码专区 | 日日狠狠久久偷偷色综合免费| 亚洲综合精品香蕉久久网| 久久亚洲AV永久无码精品| 久久精品成人免费网站| 伊人色综合久久天天人手人婷| 国产精品成人久久久久三级午夜电影| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久国产高清字幕中文| 亚洲综合精品香蕉久久网| 97香蕉久久夜色精品国产 | 久久亚洲av无码精品浪潮| 91麻精品国产91久久久久| 日本免费一区二区久久人人澡| 9久久9久久精品| 狠狠色丁香久久综合五月|