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

            常用鏈接

            統(tǒng)計

            積分與排名

            百事通

            最新評論

            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)  編輯 收藏 引用


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            国内高清久久久久久| 久久久久亚洲AV无码去区首| 久久国产精品免费一区| 日韩精品无码久久久久久| 亚洲精品国精品久久99热| 精品久久久久久国产三级| 久久96国产精品久久久| 国内精品久久久久伊人av| 久久久久亚洲av无码专区喷水| 久久99国产精品久久99小说 | 性高湖久久久久久久久AAAAA| 99久久婷婷国产一区二区| 国产L精品国产亚洲区久久| 伊人热人久久中文字幕| 久久精品国产黑森林| 久久青青草原亚洲av无码| 久久人人超碰精品CAOPOREN| 精品久久久无码中文字幕天天| 99久久伊人精品综合观看| 久久人人爽人人精品视频| 久久综合久久综合亚洲| 久久精品无码专区免费东京热 | 久久久精品人妻无码专区不卡| 狠狠精品干练久久久无码中文字幕| 久久成人18免费网站| 成人综合久久精品色婷婷| 久久久久久国产精品无码超碰 | 国产成人精品综合久久久| 欧美日韩中文字幕久久久不卡 | 精品久久无码中文字幕| 国产免费久久久久久无码| 影音先锋女人AV鲁色资源网久久| 久久精品99久久香蕉国产色戒 | 久久美女网站免费| 亚洲人成电影网站久久| 久久综合狠狠色综合伊人| 一本大道久久香蕉成人网| 狠狠色丁香久久综合五月| 一本色道久久综合| 精品久久久久中文字| 精品久久无码中文字幕|