• <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  判斷數組是否是查找二叉樹的輸入序列

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

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

              使用了分治算法,用以解決該問題。

            二 代碼如下:
              
            #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++)//很可能右子樹或者左子樹為空,考慮此種情況 
                 {
                   
            if(a[i] >= a[h])
                    
            break ;            
                 }

                 
                 
            for(j = i ; j < h ;j++
                  
            {
                    
            if(a[j] < a[h]) //若出現比尾部小的值,則返回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) 評論(0)  編輯 收藏 引用 所屬分類: 算法相關

            国产AV影片久久久久久 | 久久精品www人人爽人人| 国产精品99久久99久久久| 久久妇女高潮几次MBA| 久久久久国产精品嫩草影院| 久久天天躁狠狠躁夜夜躁2014| 一本色道久久综合狠狠躁篇 | 亚洲人成无码久久电影网站| 久久亚洲AV无码西西人体| 欧美精品丝袜久久久中文字幕| 青青热久久国产久精品| 一极黄色视频久久网站| 久久综合给久久狠狠97色| 亚洲国产成人久久综合一区77| 无码任你躁久久久久久老妇| 蜜桃麻豆WWW久久囤产精品| 热re99久久精品国产99热| 97久久精品午夜一区二区| 久久精品免费网站网| 久久综合给合久久狠狠狠97色| 国产成人精品久久一区二区三区| 亚洲国产精品久久久久久| 奇米影视7777久久精品人人爽| 久久香蕉国产线看观看精品yw| 久久精品一区二区国产| 久久久久久久波多野结衣高潮 | 久久久午夜精品福利内容| 久久夜色精品国产噜噜噜亚洲AV| 久久综合丁香激情久久| 久久精品综合网| 国产福利电影一区二区三区,免费久久久久久久精 | 久久亚洲高清观看| 久久狠狠高潮亚洲精品| 久久亚洲美女精品国产精品| 国产亚洲精久久久久久无码77777 国产亚洲精品久久久久秋霞 | 丁香久久婷婷国产午夜视频| 久久精品国产精品国产精品污| 波多野结衣中文字幕久久| 91精品国产9l久久久久| 久久精品成人免费看| 国产福利电影一区二区三区,免费久久久久久久精 |