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

            misschuer

            常用鏈接

            統計

            積分與排名

            百事通

            最新評論

            Pebble Merging

            #include <iostream>
            using namespace std;

            int main()
            {
                
            int dpmin[ 200 ][ 200 ] , min[ 200 ][ 200 ] , mins;
                
                
            int dpmax[ 200 ][ 200 ] , max[ 200 ][ 200 ] , maxs;
                
                
            int a[ 200 ] , i , n , j , k , temp , l;
                
                
            while (scanf ("%d" , & n) != EOF)
                
            {
                    
                    
            for (i = 1 ; i <= n ; ++ i)
                        
                        scanf (
            "%d" , & a[ i ]);
                    
                    
            for (i = 1 ; i < n ; ++ i)
                        
                        a[i 
            + n] = a[ i ];
                    
                    
            for (i = 1 ; i < 2 * n ; ++ i)
                    
            {    
                        min[ i ][ i ] 
            = max[ i ][ i ] = 0;
                        
                        dpmax[ i ][ i ] 
            = dpmin[ i ][ i ] = a[ i ];
                        
                        dpmax[ i ][i 
            + 1= dpmin[ i ][i + 1= a[ i ] + a[i + 1];
                        
                        min[ i ][i 
            + 1= max[ i ][i + 1= a[ i ] + a[i + 1];
                    }

                    
                    
            for (i = 1 ; i < n - 1++ i)
                        
                        
            for (l = 1 , j = 2 + i ; j < 2 * n ; ++ j , ++ l)
                        
            {
                            
            for (k = l + 1 ; k <= j ; ++ k)
                            
            {
                                
                                
            if (k == l + 1)
                                
            {
                                    dpmin[ l ][ j ] 
            = dpmin[ l ][k - 1+ dpmin[ k ][ j ] + min[ l ][k - 1+ min[ k ][ j ];
                                    
                                    
            if ( l == k - 1 && k != j)
                                        
                                        min[ l ][ j ] 
            = a[ l ] + min[ k ][ j ];
                                    
                                    
            else
                                        
                                        
            if (l != k - 1 && k == j)
                                            
                                            min[ l ][ j ] 
            = min[ l ][k - 1+ a[ k ];
                                        
                                        
            else
                                            
                                            min[ l ][ j ] 
            = min[ l ][k - 1+ min[ k ][ j ];
                                        
                                        dpmax[ l ][ j ] 
            = dpmax[ l ][k - 1+ dpmax[ k ][ j ] + max[ l ][k - 1+ max[ k ][ j ];
                                        
                                        
                                        
                                        
            if ( l == k - 1 && k != j)
                                            
                                            max[ l ][ j ] 
            = a[ l ] + max[ k ][ j ];
                                        
                                        
            else
                                            
                                            
            if (l != k - 1 && k == j)
                                                
                                                max[ l ][ j ] 
            = max[ l ][k - 1+ a[ k ];
                                            
                                            
            else
                                                
                                                max[ l ][ j ] 
            = max[ l ][k - 1+ max[ k ][ j ];
                                            
                                            
            continue ;
                                }

                                
                                temp 
            = dpmin[ l ][k - 1+ dpmin[ k ][ j ] + min[ l ][k - 1+ min[ k ][ j ];
                                
                                
            if (temp < dpmin[ l ][ j ])
                                
            {
                                    dpmin[ l ][ j ] 
            = temp;
                                    
                                    
            if ( l == k - 1 && k != j)
                                        
                                        min[ l ][ j ] 
            = a[ l ] + min[ k ][ j ];
                                    
                                    
            else
                                        
                                        
            if (l != k - 1 && k == j)
                                            
                                            min[ l ][ j ] 
            = min[ l ][k - 1+ a[ k ];
                                        
                                        
            else
                                            
                                            min[ l ][ j ] 
            = min[ l ][k - 1+ min[ k ][ j ];
                                }

                                temp 
            = dpmax[ l ][k - 1+ dpmax[ k ][ j ] + max[ l ][k - 1+ max[ k ][ j ];
                                
                                
            if (temp > dpmax[ l ][ j ])
                                
            {
                                    dpmax[ l ][ j ] 
            = temp;
                                    
                                    
            if ( l == k - 1 && k != j)
                                        
                                        max[ l ][ j ] 
            = a[ l ] + max[ k ][ j ];
                                    
                                    
            else
                                        
                                        
            if (l != k - 1 && k == j)
                                            
                                            max[ l ][ j ] 
            = max[ l ][k - 1+ a[ k ];
                                        
                                        
            else
                                            
                                            max[ l ][ j ] 
            = max[ l ][k - 1+ max[ k ][ j ];
                                }

                                
                            }

                           
                            
                          
                        
                        }

                        
                     
                        mins 
            = dpmin[ 1 ][ n ];  maxs = dpmax[ 1 ][ n ];

                          
            for (i = 2 ; i <= n  ; ++ i)
                          
            {
                              
            if (mins > dpmin[ i ][i + n - 1])

                                  mins 
            = dpmin[ i ][i + n - 1];

                              
            if (maxs < dpmax[ i ][i + n - 1])

                                 maxs 
            = dpmax[ i ][i + n - 1];


                          }

                            printf (
            "%d\n%d\n" , mins , maxs);
                        
                    }

                
                
            return 23;
                
            }

            posted on 2009-04-21 19:25 此最相思 閱讀(159) 評論(0)  編輯 收藏 引用

            久久精品成人免费网站| 亚洲午夜精品久久久久久app| 狠狠综合久久AV一区二区三区| 一本久久综合亚洲鲁鲁五月天| 一个色综合久久| 国产精品99精品久久免费| 色综合久久中文综合网| 久久精品国产72国产精福利| 久久成人小视频| 亚洲嫩草影院久久精品| 精品久久久中文字幕人妻| 久久99国产精品久久99果冻传媒| 久久精品夜色噜噜亚洲A∨| 亚洲国产精品无码久久一线 | 亚洲欧美成人久久综合中文网| 大香伊人久久精品一区二区| 一本久久a久久精品综合香蕉| 精品国产青草久久久久福利| 久久久亚洲欧洲日产国码是AV| 久久伊人精品青青草原高清| 久久亚洲AV无码精品色午夜麻豆| 亚洲一本综合久久| 国产精品美女久久久久| 久久人人超碰精品CAOPOREN| 久久亚洲私人国产精品vA| 国产69精品久久久久APP下载| 国产精品欧美亚洲韩国日本久久| 99久久99这里只有免费费精品| 国产69精品久久久久9999APGF | 丁香五月综合久久激情| 久久亚洲AV成人无码电影| 亚洲狠狠婷婷综合久久蜜芽| 一级做a爰片久久毛片看看| 久久影院亚洲一区| 亚洲伊人久久综合影院| 久久亚洲中文字幕精品一区| 麻豆久久久9性大片| 国产激情久久久久久熟女老人| 午夜精品久久久久| 久久人妻少妇嫩草AV无码专区| 午夜精品久久久久久久久|