• <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>
            隨筆 - 97, 文章 - 22, 評(píng)論 - 81, 引用 - 0
            數(shù)據(jù)加載中……

            Pku 2958 Pizza delivery (DP)

            問(wèn)題描述:
            要求求一個(gè)點(diǎn)(r, c)使得它到達(dá)(i, j)的曼哈頓距離與該點(diǎn)權(quán)值乘積總和最小,其中(1 <= i <= n, 1 <= j <= m)
            (1 <= n, m <= 100) 因此,暴力的復(fù)雜度是O(n^4),顯然是TLE的,想了一下,想到一個(gè)O(n^3)的算法,算法核心還是DP。
            解題思路:
            首先定義:
            map[i][j]       表示原圖(i, j)這個(gè)點(diǎn)的權(quán)值
            sum[i][j]       表示第1行一直到第i行中所有第j列的權(quán)值總和
            rt[i][j]           表示以該點(diǎn)為(r, c)而得到的權(quán)值總和
            答案就是 Min = min{rt[i][j] , (1 <= i <= n, 1 <= j <= m) }

            首先預(yù)處理sum[i][j] ,然后每次暴力計(jì)算rt[i][1]的值,由于rt[i][j-1] 和rt[i][j]相鄰,于是他們相對(duì)于別的點(diǎn)曼哈頓距離必定均相差1,每次計(jì)算rt[i][j]只要枚舉列k,如果第k列在j-1以及其左邊那么rt[i][j] 比rt[i][j-1]大sum[n][k],否則要小sum[n][k],于是問(wèn)題就解決了,每次統(tǒng)計(jì)rt[i][j]然后取最小值即可。

            核心代碼:
               if(k <= j-1)
                     rt[i][j] 
            += sum[n][k];
              
            else
                     rt[i][j] 
            -= sum[n][k];

            #include <iostream>

            using namespace std;

            int n, m, i, j, k;
            int Min;
            int map[101][101];
            int sum[101][101];    
            int rt[101][101];

            int main()
            {
                
            int t;
                scanf(
            "%d"&t);
                
            while(t--)
                
            {
                    Min 
            = -1;
                    scanf(
            "%d %d"&m, &n);

                    
            for(i = 1; i <= n; i++)
                    
            {
                        
            for(j = 1; j <= m; j++)
                        
            {
                            scanf(
            "%d"&map[i][j]);
                        }

                    }


                    
            for(i = 1; i <= n; i++)
                    
            {
                        
            for(j = 1; j <= m; j++)
                            sum[i][j] 
            = sum[i-1][j] + map[i][j];
                    }


                    
            for(i = 1; i <= n; i++)
                    
            {
                        rt[i][
            1= 0;

                        
            //計(jì)算(i, 1) 這個(gè)點(diǎn)作為Ketichen的距離和
                        for(j = 1; j <= n; j++)
                        
            {
                            
            for(k = 1; k <= m; k++)
                            
            {
                                rt[i][
            1+= ( abs(i-j) + abs(k-1) ) * map[j][k];
                            }

                        }


                        
            if(Min == -1 || rt[i][1< Min)
                            Min 
            = rt[i][1];

                        
            //根據(jù)(i, j-1)計(jì)算(i, j)的值
                        for(j = 2; j <= m; j++)
                        
            {
                            rt[i][j] 
            = rt[i][j-1];

                            
            for(k = 1; k <= m; k++)
                            
            {
                                
            if(k <= j-1)
                                    rt[i][j] 
            += sum[n][k];
                                
            else
                                    rt[i][j] 
            -= sum[n][k];
                            }

                            
            if(Min == -1 || rt[i][j] < Min)
                                Min 
            = rt[i][j];
                        }

                    }


                    printf(
            "%d blocks\n", Min);
                }

            }

            posted on 2009-02-08 22:43 英雄哪里出來(lái) 閱讀(349) 評(píng)論(0)  編輯 收藏 引用 所屬分類: ACM

            国产激情久久久久影院老熟女| 中文字幕久久精品无码| 99精品久久久久久久婷婷| 久久国产V一级毛多内射| 99热热久久这里只有精品68| 久久精品国产69国产精品亚洲| 精品一区二区久久久久久久网站| 波多野结衣中文字幕久久| 久久精品国产亚洲精品2020| 99久久婷婷免费国产综合精品| 777米奇久久最新地址| 国产一区二区精品久久岳| 久久国产香蕉一区精品| 亚洲精品99久久久久中文字幕| 中文字幕亚洲综合久久菠萝蜜| 亚洲va久久久噜噜噜久久天堂| 久久久久人妻一区二区三区vr| 99久久精品无码一区二区毛片 | 欧美一区二区三区久久综合| 久久久久亚洲AV片无码下载蜜桃 | 久久香蕉国产线看观看猫咪?v| 日韩亚洲国产综合久久久| 久久婷婷人人澡人人爽人人爱| 国产精品久久国产精品99盘| 91久久精品国产91性色也| 狠狠色丁香久久婷婷综合蜜芽五月| 婷婷久久香蕉五月综合加勒比| 91亚洲国产成人久久精品| 久久强奷乱码老熟女网站| 无码人妻精品一区二区三区久久| 一本伊大人香蕉久久网手机| 伊人久久大香线蕉无码麻豆| 久久这里只精品国产99热| 少妇无套内谢久久久久| 亚洲国产精品久久久久久| 亚洲成色WWW久久网站| 久久人人爽人爽人人爽av| 91精品国产乱码久久久久久 | 精品久久久久中文字| 久久久久久夜精品精品免费啦| 免费一级欧美大片久久网|