• <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>
            不錯的DP題。狀態(tài)f[i][x1][y1][x2][y2]表示要把(x1,y1) -- (x2, y2) 分割成i塊所得到的最小平方和(平方和指的是每塊矩形的和的平方和)。然后根據(jù)水平和豎直切割進行狀態(tài)轉(zhuǎn)移。這樣計算出f[n][1][1][8][8]得到整個棋盤分割成n塊得到的最小平方和,然后代入均方差公式算得結(jié)果。


            /*************************************************************************
            Author: WHU_GCC
            Created Time: 2007-10-1 19:01:11
            File Name: pku1191.cpp
            Description: 
            ***********************************************************************
            */

            #include 
            <iostream>
            #include 
            <cmath>
            using namespace std;

            #define out(x) (cout << #x << ": " << x << endl)
            typedef 
            long long int64;
            const int maxint = 0x7FFFFFFF;
            const int64 maxint64 = 0x7FFFFFFFFFFFFFFFLL;
            template 
            <class T> void show(T a, int n) for (int i = 0; i < n; ++i) cout << a[i] << ' '; cout << endl; }
            template 
            <class T> void show(T a, int r, int l) for (int i = 0; i < r; ++i) show(a[i], l); cout << endl; }

            int n;
            int a[9][9], g[9][9];
            int f[16][9][9][9][9];

            inline 
            int sum(int x1, int y1, int x2, int y2)
            {
                
            return (g[x2][y2] - g[x1 - 1][y2] - g[x2][y1 - 1+ g[x1 - 1][y1 - 1])
                    
            * (g[x2][y2] - g[x1 - 1][y2] - g[x2][y1 - 1+ g[x1 - 1][y1 - 1]);
            }


            int dp(int k, int x1, int y1, int x2, int y2)
            {
                
            if (f[k][x1][y1][x2][y2] != maxint)
                    
            return f[k][x1][y1][x2][y2];
                
            if (k == 1)
                    
            return f[k][x1][y1][x2][y2] = sum(x1, y1, x2, y2);
                
            if (x1 == x2 && y1 == y2)
                    
            return f[k][x1][y1][x2][y2] = sum(x1, y1, x2, y2);
                
            int ret = maxint;
                
            for (int i = x1; i < x2; i++)
                
            {
                    ret 
            <?= dp(k - 1, x1, y1, i, y2) + sum(i + 1, y1, x2, y2);
                    ret 
            <?= sum(x1, y1, i, y2) + dp(k - 1, i + 1, y1, x2, y2);
                }

                
            for (int i = y1; i < y2; i++)
                
            {
                    ret 
            <?= dp(k - 1, x1, y1, x2, i) + sum(x1, i + 1, x2, y2);
                    ret 
            <?= sum(x1, y1, x2, i) + dp(k - 1, x1, i + 1, x2, y2);
                }

                
            return f[k][x1][y1][x2][y2] = ret;
            }


            int main()
            {
                scanf(
            "%d"&n);
                
            for (int i = 1; i <= 8; i++)
                    
            for (int j = 1; j <= 8; j++)
                        scanf(
            "%d"&a[i][j]);
                memset(g, 
            0sizeof(g));

                
            for (int i = 0; i <= 8; i++)
                    
            for (int j = 0; j <= 8; j++)
                        g[i][j] 
            = g[i - 1][j] + g[i][j - 1- g[i - 1][j - 1+ a[i][j];
                
                
            for (int k = 0; k <= 15; k++)
                    
            for (int x1 = 1; x1 <= 8; x1++)
                        
            for (int y1 = 1; y1 <= 8; y1++)
                            
            for (int x2 = 1; x2 <= 8; x2++)
                                
            for (int y2 = 1; y2 <= 8; y2++)
                                    f[k][x1][y1][x2][y2] 
            = maxint;
                
                
            double sum = 0.0;
                
            for (int i = 1; i <= 8; i++)
                    
            for (int j = 1; j <= 8; j++)
                        sum 
            += a[i][j];
                sum 
            /= n;
                sum 
            *= sum;

                printf(
            "%.3lf\n", sqrt(dp(n, 1188/ double(n) - sum));
                
            return 0;
            }
            posted on 2007-10-08 09:12 Felicia 閱讀(808) 評論(1)  編輯 收藏 引用 所屬分類: 動態(tài)規(guī)劃
            Comments
             
            无码人妻久久一区二区三区免费| 久久久久久亚洲精品成人| 99久久精品国产一区二区三区| 久久精品人人做人人妻人人玩| 久久久青草久久久青草| 久久久久国产日韩精品网站| 奇米影视7777久久精品人人爽| 日本强好片久久久久久AAA| 青青青国产成人久久111网站| 欧美久久一级内射wwwwww.| 一本一本久久aa综合精品| 久久99精品国产99久久6男男| 久久久这里只有精品加勒比| 久久免费精品视频| 久久精品国产久精国产一老狼| 久久99毛片免费观看不卡| 欧美亚洲国产精品久久高清| 国产精品99久久久久久宅男| 欧洲成人午夜精品无码区久久| 久久婷婷五月综合成人D啪| 国产日产久久高清欧美一区| 亚洲日韩欧美一区久久久久我| 久久久国产精品福利免费| 久久水蜜桃亚洲av无码精品麻豆 | 久久久久九九精品影院| 国产成人精品久久二区二区| 精品伊人久久大线蕉色首页| 日韩电影久久久被窝网| 久久九九久精品国产免费直播| 99久久精品毛片免费播放| 亚洲va久久久噜噜噜久久 | 久久免费视频一区| 91久久香蕉国产熟女线看| 国产精品久久久久久吹潮| 久久久久亚洲AV无码网站| 久久久久成人精品无码中文字幕| 亚洲国产天堂久久综合| 久久国产欧美日韩精品免费| 亚洲乱码日产精品a级毛片久久| 国内精品久久久久久久久电影网| 久久99免费视频|