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

            pku3686 The Windy's 匹配好題!

            引用:

            [PKU][POJ][3686][THE WINDY'S]

            –author: Answeror 
            —title: [PKU][3686][The Windy's] 
            —-link: http://acm.pku.edu.cn/JudgeOnline/problem?id=3686 
            —-date: 2009-08-20 
            -problem: 有m個(gè)工廠, n筆訂單, 訂單i在j廠完成所需時(shí)間為c[i][j], 要求一筆訂單只能在一個(gè)廠完成, 一個(gè)廠不能同時(shí)做一筆以上訂單, 求一個(gè)分配方案, 使得每個(gè)任務(wù)的平均完成時(shí)間最小. 
            solution: 拆點(diǎn), 以"第i個(gè)任務(wù)是j廠的倒數(shù)第k個(gè)任務(wù)"為頂點(diǎn)建圖, KM算法求解二分圖最小權(quán)匹配. 
            —-code: http://docs.google.com/View?id=dgtsspfh_60hg9pwj2j

            本題的建圖方法很有意思, 我解這題的思維過程也挺有意思.

            剛看到這題, 因?yàn)椴抛鲞^[PKU][2516], 馬上想到了帶權(quán)二分匹配, 并且工廠和任務(wù)是一對(duì)多的關(guān)系, 很可能是要拆點(diǎn), 把工廠拆開來. 于是馬上開始敲鍵盤, 以訂單為X集, 訂單i在工廠j完成為Y集建圖, 代碼敲了幾行感覺有點(diǎn)不對(duì)勁, 于是回過頭再去看看題目要求什么, 一看果然是理解錯(cuò)了, 題目要求的是完成時(shí)間的平均值, 而不是生產(chǎn)時(shí)間的平均值, 完成時(shí)間還包括了等待的時(shí)間.

            嗯, 那么Y集的狀態(tài)應(yīng)該改改, 既然主線是轉(zhuǎn)化成帶權(quán)二分匹配, 而且按這個(gè)數(shù)據(jù)規(guī)模來看不可能兩邊都是2500的頂點(diǎn), 肯定有一邊是50, 另一邊是50或2500, 那么最后只有50條邊被選中, 因?yàn)槎制ヅ渲械拿織l邊最多只累計(jì)一次, 所以不會(huì)產(chǎn)生"累加"的效果, 所以這50條邊每條都必須能完全獨(dú)立地表達(dá)"某訂單在某工廠耗費(fèi)的總時(shí)間". 第一反應(yīng)當(dāng)然是想把Y集頂點(diǎn)表示工廠j第k個(gè)訂單, 當(dāng)然這肯定是不對(duì)的, 前k-1個(gè)任務(wù)根本不能確定, 那這條邊又怎么能完全獨(dú)立地表達(dá)"某訂單在某工廠耗費(fèi)的總時(shí)間"呢?

            再回到題目中去, 他要求平均時(shí)間, 就是總時(shí)間除n, 我們要求的是總時(shí)間, 總時(shí)間可以表示成每筆訂單各自的完成時(shí)間相加, 把每筆訂單各自的完成時(shí)間再寫出來, 就是它之前的所有訂單的生產(chǎn)時(shí)間加上它自己的生產(chǎn)時(shí)間, 而它之前的一個(gè)任務(wù)的完成時(shí)間再拆開來看…為什么要把每個(gè)訂單的完成時(shí)間看成一個(gè)整體呢? 換個(gè)思路, 若訂單i在廠j完成后, 后面還有k個(gè)任務(wù), 那么這個(gè)總時(shí)間就還要加上k份i的生產(chǎn)時(shí)間. 那么就把Y集頂點(diǎn)表示成工廠j完成倒數(shù)第k個(gè)好了, 這樣就把每筆訂單的生產(chǎn)時(shí)間以及延誤其他訂單的時(shí)間看成一個(gè)整體(生產(chǎn)時(shí)間又可以看成是延誤自己的時(shí)間). 后面就是套KM模板的事情了.

            代碼:
             1 Source Code
             2 
             3 Problem: 3686        User: yzhw
             4 Memory: 1024K        Time: 16MS
             5 Language: G++        Result: Accepted
             6 Source Code
             7 # include <cstdio>
             8 # include <cstring>
             9 using namespace std;
            10 # define max(a,b) ((a)>(b)?(a):(b))
            11 # define min(a,b) ((a)<(b)?(a):(b))
            12 # define N 55
            13 # define M 3000
            14 int val[N][M],n,m,ln[N],rn[M],match[M];
            15 bool l[N],r[M];
            16 bool dfs(int pos)
            17 {
            18    l[pos]=true;
            19    for(int i=0;i<n*m;i++)
            20      if(!r[i]&&ln[pos]+rn[i]==val[pos][i])
            21      {
            22         r[i]=true;
            23         if(match[i]==-1||dfs(match[i]))
            24         {
            25             match[i]=pos;
            26             return true;
            27         }
            28      }
            29      return false;
            30 }
            31 void adjust()
            32 {
            33     int minnum=0xfffffff;
            34     for(int i=0;i<n;i++)
            35       if(l[i])
            36          for(int j=0;j<n*m;j++)
            37            if(!r[j])
            38               minnum=min(minnum,ln[i]+rn[j]-val[i][j]);
            39     for(int i=0;i<n;i++)
            40       if(l[i]) ln[i]-=minnum;
            41     for(int i=0;i<n*m;i++)
            42       if(r[i]) rn[i]+=minnum;
            43       
            44 }
            45 int main()
            46 {
            47     int test;
            48     scanf("%d",&test);
            49     while(test--)
            50     {
            51         scanf("%d%d",&n,&m);
            52         for(int i=0;i<n;i++)
            53           for(int j=0;j<m;j++)
            54           {
            55             scanf("%d",&val[i][j]);
            56             val[i][j]*=-1;
            57           }
            58         for(int k=1;k<=n;k++)
            59            for(int i=0;i<n;i++)
            60              for(int j=0;j<m;j++)
            61                 val[i][(k-1)*m+j]=k*val[i][j];
            62         memset(rn,0,sizeof(rn));
            63         for(int i=0;i<n;i++)
            64         {
            65            int maxnum=-0xfffffff;
            66            for(int j=0;j<n*m;j++)
            67              maxnum=max(maxnum,val[i][j]);
            68            ln[i]=maxnum;
            69         }
            70         memset(match,-1,sizeof(match));
            71         for(int i=0;i<n;i++)
            72         {
            73             memset(l,0,sizeof(l));
            74             memset(r,0,sizeof(r));
            75             while(!dfs(i))
            76             {
            77               adjust();
            78               memset(l,0,sizeof(l));
            79               memset(r,0,sizeof(r));
            80             }
            81         }
            82         int total=0;
            83         for(int i=0;i<n*m;i++)
            84           if(match[i]!=-1)
            85             total-=val[match[i]][i];
            86         printf("%.6f\n",(double)total/n);  
            87     }
            88     return 0;
            89 }

            posted on 2011-03-08 01:47 yzhw 閱讀(287) 評(píng)論(0)  編輯 收藏 引用 所屬分類: graph

            <2010年11月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            導(dǎo)航

            統(tǒng)計(jì)

            公告

            統(tǒng)計(jì)系統(tǒng)

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評(píng)論

            閱讀排行榜

            久久96国产精品久久久| 久久人妻无码中文字幕| 99久久国产综合精品网成人影院 | 亚洲国产精品综合久久一线| 亚洲人成网站999久久久综合| 欧美熟妇另类久久久久久不卡| 国产精品99久久久久久www| 中文字幕精品久久| 狠狠干狠狠久久| 久久AV无码精品人妻糸列| 国产激情久久久久影院| 亚洲va久久久噜噜噜久久狠狠 | 97久久精品无码一区二区| 人妻中文久久久久| 9191精品国产免费久久| 一本色道久久99一综合| 久久久久亚洲AV无码专区网站| 精品蜜臀久久久久99网站| 欧美久久久久久| 久久亚洲AV无码西西人体| 99精品久久久久久久婷婷| 久久亚洲欧美国产精品| 狠狠色综合网站久久久久久久高清 | A狠狠久久蜜臀婷色中文网| 亚洲日本va午夜中文字幕久久| 亚洲AV无码久久精品成人| 波多野结衣久久精品| 久久成人18免费网站| 国产91久久综合| 久久免费精品视频| 国产成人精品久久亚洲高清不卡| 国产成人久久AV免费| AV无码久久久久不卡网站下载| 奇米影视7777久久精品| 色婷婷久久综合中文久久蜜桃av| 久久精品一本到99热免费| 国产精品亚洲综合久久| 波多野结衣AV无码久久一区| 久久99久久99精品免视看动漫| 精品无码久久久久国产动漫3d| 久久91精品国产91|