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

            動(dòng)態(tài)規(guī)劃法-------最大連續(xù)子序列和

                             動(dòng)態(tài)規(guī)劃法解決最大連續(xù)子序列和

                 問(wèn)題描述 :
                   數(shù)組 int a[] = {-4 , 3 ,56 , -15 , 34 , 0 , -14 , 4} ; 某幾個(gè)連續(xù)的子序列其和最大,比如a0+a1 = -1 。a1+a2+a3+a4 = 78 。則a1 a2 a3a4組成的數(shù)組即是所求。
                  


                 解決方法:
                    此題嘗試使用動(dòng)態(tài)規(guī)劃的方法進(jìn)行解決,首先建立狀態(tài)方程。
                   設(shè)b[j]表示第j處,以a[j] 結(jié)尾的子序列的最大和。
                   則b[j] = max(a[j] + b[j-1] , a[j]) ,而我們的所求的答案,就是從1- n對(duì)b數(shù)組求最大值。
                

             代碼如下:
                  

              
            /*
             最大連續(xù)字段和 時(shí)間復(fù)雜度為O(N) 
             定義b[j]為數(shù)組中包含a[j]的最大連續(xù)子序列和
             注意一個(gè)誤區(qū),b[j] 并不是1-j中最大的連續(xù)子序列的和,只是包含a[j]的最大子序列的和 
             而我們所要求的是求出b[j]中最大的值,即為所求 

             狀態(tài)方程為: b[j] = max(b[j-1] + a[j] , a[j]) 
            */

            #include 
            <iostream>
             
            using namespace std ;
             
            const int N = 8 ;
             
            int a[] = {-4 , 3 ,56 , -15 , 34 , 0 , -14 , 4} ;
             
            int b[N] ; //b[i]表示包含a[i]的最大連續(xù)子序列之和 
             inline int max(int a , int b) 
             
            {
               
            return (a > b) ? a : b ;       
             }

             
            int main()
             
            {
               b[
            0= a[0] ;  
               
            int i , mam = b[0];   
               
            for(i = 1;  i < N ; i++)
               

                 b[i] 
            = max(a[i] , b[i-1+ a[i]);   
                 
            if(mam < b[i])
                   mam 
            = b[i] ;     
               }

               printf(
            "max %d\n" , mam) ;
               
               
            for(i = 0;  i < N ; i++)   
                 printf(
            "%d\n" , b[i]) ;
               system(
            "pause") ;    
               
            return 0 ;  
             }

              

            posted on 2011-04-21 13:54 kahn 閱讀(9641) 評(píng)論(3)  編輯 收藏 引用 所屬分類(lèi): 算法相關(guān)

            Feedback

            # re: 動(dòng)態(tài)規(guī)劃法-------最大連續(xù)子序列和[未登錄](méi) 2013-04-10 17:20 123

            感覺(jué)這個(gè)是錯(cuò)的吧 b[j] = max(a[j] + b[j-1] , a[j])   回復(fù)  更多評(píng)論   

            # re: 動(dòng)態(tài)規(guī)劃法-------最大連續(xù)子序列和[未登錄](méi) 2013-04-10 17:24 123

            比如這種情況
            -1 -1 9 9 9 -1 -1

            -1 -1 9 9 9 -1 -1 9

            b[7] == 27
            按照你的公式
            b[8] == 36 而事實(shí)上等于 34  回復(fù)  更多評(píng)論   

            # re: 動(dòng)態(tài)規(guī)劃法-------最大連續(xù)子序列和 2013-10-05 06:41 456

            @123
            誰(shuí)說(shuō)的,明明b[7] == 25好吧  回復(fù)  更多評(píng)論   


            午夜精品久久久久久| 久久人妻少妇嫩草AV蜜桃| 久久久91精品国产一区二区三区 | 午夜久久久久久禁播电影| 久久久国产乱子伦精品作者| 2021国产成人精品久久| 久久天天躁狠狠躁夜夜不卡| 2021国产成人精品久久| 久久久久亚洲av成人网人人软件| 久久久久四虎国产精品| 久久精品国产99国产精品导航| 老司机国内精品久久久久| 影音先锋女人AV鲁色资源网久久| 久久这里只有精品久久| 99精品国产99久久久久久97 | 国产精品99久久久久久猫咪| 久久精品国产亚洲AV蜜臀色欲 | 欧美日韩精品久久久久| 国产欧美久久久精品| 久久亚洲日韩精品一区二区三区| 久久精品国产一区二区三区不卡 | 久久综合视频网站| 国产—久久香蕉国产线看观看| 久久综合给合久久狠狠狠97色 | 久久99精品久久久久久hb无码| 色综合久久久久综合99| 久久精品国产亚洲一区二区三区| 久久精品国产99国产精品澳门| 久久久久久夜精品精品免费啦| 久久久久波多野结衣高潮| 亚洲国产精品综合久久一线| 青青草原综合久久大伊人导航| segui久久国产精品| 88久久精品无码一区二区毛片 | 人妻无码久久精品| 久久人搡人人玩人妻精品首页 | 中文字幕乱码久久午夜| 伊人久久大香线蕉综合影院首页 | 亚洲国产精品无码久久98| 亚洲精品乱码久久久久久按摩| 久久精品中文无码资源站|