• <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 此最相思 閱讀(154) 評論(0)  編輯 收藏 引用

            久久伊人五月天论坛| 欧美国产精品久久高清| 性欧美大战久久久久久久| 精品久久久久久久久中文字幕| 久久免费视频1| 日本精品久久久久影院日本| 国产精品美女久久久久AV福利| 狠狠色婷婷综合天天久久丁香| 国产成人无码久久久精品一| 久久精品亚洲一区二区三区浴池| 婷婷伊人久久大香线蕉AV| 亚洲AV无码一区东京热久久| 亚洲狠狠婷婷综合久久蜜芽| 亚洲精品乱码久久久久久久久久久久| 久久精品成人欧美大片| 久久经典免费视频| 日韩欧美亚洲综合久久 | 精品综合久久久久久98| 亚洲第一永久AV网站久久精品男人的天堂AV| 久久精品成人免费观看97| 久久久久亚洲精品中文字幕| 无码乱码观看精品久久| 色妞色综合久久夜夜| 国产V综合V亚洲欧美久久| 久久综合综合久久97色| 精品无码人妻久久久久久| 久久青青草原精品国产不卡| 亚洲精品美女久久久久99小说| 久久久无码精品亚洲日韩京东传媒 | 日产精品99久久久久久| 久久精品中文闷骚内射| 激情伊人五月天久久综合| 国产成人久久久精品二区三区| 久久亚洲视频| 亚洲AV无码久久精品色欲| 精品精品国产自在久久高清| 久久久噜噜噜久久中文字幕色伊伊| 伊人久久无码精品中文字幕| 久久亚洲AV成人无码国产| 伊人久久综在合线亚洲2019| 伊人色综合九久久天天蜜桃|