• <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>

            jake1036

            面試100題-06

              面試100題-06  判斷數(shù)組是否是查找二叉樹(shù)的輸入序列

             一 問(wèn)題描述: 
            該題目主要判讀輸入的數(shù)組,是否是查找樹(shù)的后序遍歷序列 ,比如一個(gè)數(shù)組 5,7,6,9,11,10,8就是一個(gè)數(shù)組序列
            這就需要利用后序遍歷查找樹(shù)的一些性質(zhì) 。
            從頭開(kāi)始掃描數(shù)組,當(dāng)發(fā)現(xiàn)第一個(gè)位置i處,a[i]大于最后一個(gè)元素,則就有從i元素開(kāi)始的每一個(gè)元素都大于尾部。
            若發(fā)現(xiàn)不滿足上述定理,則證明該數(shù)組不是后序遍歷序列。

            解決方法:
             利用遞歸方法,首先確定遍歷數(shù)組,找出第一個(gè)大于尾部元素位置,即為i。然后從i開(kāi)始掃描到尾部判讀是否都比
             尾部元素大。同理掃描1-i-1 元素,判斷是否都比a[i]大。

              使用了分治算法,用以解決該問(wèn)題。

            二 代碼如下:
              
            #include <iostream>
             
            using namespace std ;
             
            const int N = 7 ;
             
            int a[N] ={5 , 7 , 6 , 9 , 11 , 10 , 8};
             
            bool judge(int l , int h)
             
            {
               
            if(l <= h)
               

                 
            int i , j ;     
                 
            for(i = l ; i <= h ; i++)//很可能右子樹(shù)或者左子樹(shù)為空,考慮此種情況 
                 {
                   
            if(a[i] >= a[h])
                    
            break ;            
                 }

                 
                 
            for(j = i ; j < h ;j++
                  
            {
                    
            if(a[j] < a[h]) //若出現(xiàn)比尾部小的值,則返回false 
                      return false ;   
                  }

                 
                 
            bool  fl = true ;
                 
            if(l <= i - 1)
                  fl 
            = judge(l, i - 1) ;
                 
                 
            bool rl = true ;
                 
            if(i <= h - 1)
                 rl 
            = judge(i , h -1) ;
                 
                 
            return fl && rl ;
               }
             
                
            return false ;
               
                  
                  
             }

             
             
             
            int main()
             
            {
              
            bool f = judge(0 , N -1) ;
              cout
            <<f<<endl ;
              
              system(
            "pause") ;
              
            return 0 ;    
             }

             





            posted on 2011-05-16 14:33 kahn 閱讀(215) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 算法相關(guān)

            久久久久亚洲AV成人网人人网站| 亚洲精品午夜国产va久久 | 国内精品久久国产大陆| 国产精品久久自在自线观看| 国产成人精品久久| 女人高潮久久久叫人喷水| 国产成人精品久久一区二区三区| 国产综合免费精品久久久| 18岁日韩内射颜射午夜久久成人| 美女写真久久影院| 一本久久a久久精品vr综合| 欧美精品一区二区精品久久| 无码国内精品久久综合88 | 天天久久狠狠色综合| 一级做a爰片久久毛片毛片| 精品久久久久久久| 久久精品国产亚洲AV影院| 国产成人精品综合久久久| 国内精品伊人久久久久AV影院| 久久高潮一级毛片免费| 精品久久久久久综合日本| 一本久久知道综合久久| 亚洲日韩欧美一区久久久久我 | 欧美黑人又粗又大久久久| 亚洲欧美日韩精品久久亚洲区| 久久99国产精品99久久| 久久国产乱子伦免费精品| 久久91精品国产91久| 人妻无码精品久久亚瑟影视| 精品久久久久久国产| 精品午夜久久福利大片| 粉嫩小泬无遮挡久久久久久| 欧美熟妇另类久久久久久不卡| 久久久久久国产a免费观看黄色大片 | 成人综合久久精品色婷婷| 93精91精品国产综合久久香蕉| 91久久精一区二区三区大全| 国产精品九九九久久九九| 国产精品久久久久天天影视| 99久久国产综合精品麻豆| 99久久免费国产精品热|