青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

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個工廠, n筆訂單, 訂單i在j廠完成所需時間為c[i][j], 要求一筆訂單只能在一個廠完成, 一個廠不能同時做一筆以上訂單, 求一個分配方案, 使得每個任務的平均完成時間最小. 
solution: 拆點, 以"第i個任務是j廠的倒數第k個任務"為頂點建圖, KM算法求解二分圖最小權匹配. 
—-code: http://docs.google.com/View?id=dgtsspfh_60hg9pwj2j

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

剛看到這題, 因為才做過[PKU][2516], 馬上想到了帶權二分匹配, 并且工廠和任務是一對多的關系, 很可能是要拆點, 把工廠拆開來. 于是馬上開始敲鍵盤, 以訂單為X集, 訂單i在工廠j完成為Y集建圖, 代碼敲了幾行感覺有點不對勁, 于是回過頭再去看看題目要求什么, 一看果然是理解錯了, 題目要求的是完成時間的平均值, 而不是生產時間的平均值, 完成時間還包括了等待的時間.

嗯, 那么Y集的狀態應該改改, 既然主線是轉化成帶權二分匹配, 而且按這個數據規模來看不可能兩邊都是2500的頂點, 肯定有一邊是50, 另一邊是50或2500, 那么最后只有50條邊被選中, 因為二分匹配中的每條邊最多只累計一次, 所以不會產生"累加"的效果, 所以這50條邊每條都必須能完全獨立地表達"某訂單在某工廠耗費的總時間". 第一反應當然是想把Y集頂點表示工廠j第k個訂單, 當然這肯定是不對的, 前k-1個任務根本不能確定, 那這條邊又怎么能完全獨立地表達"某訂單在某工廠耗費的總時間"呢?

再回到題目中去, 他要求平均時間, 就是總時間除n, 我們要求的是總時間, 總時間可以表示成每筆訂單各自的完成時間相加, 把每筆訂單各自的完成時間再寫出來, 就是它之前的所有訂單的生產時間加上它自己的生產時間, 而它之前的一個任務的完成時間再拆開來看…為什么要把每個訂單的完成時間看成一個整體呢? 換個思路, 若訂單i在廠j完成后, 后面還有k個任務, 那么這個總時間就還要加上k份i的生產時間. 那么就把Y集頂點表示成工廠j完成倒數第k個好了, 這樣就把每筆訂單的生產時間以及延誤其他訂單的時間看成一個整體(生產時間又可以看成是延誤自己的時間). 后面就是套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 閱讀(306) 評論(0)  編輯 收藏 引用 所屬分類: graph

<2011年3月>
272812345
6789101112
13141516171819
20212223242526
272829303112
3456789

導航

統計

公告

統計系統

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美精品久久久久久| 亚洲一级特黄| 激情成人亚洲| 亚洲国产一区二区三区在线播| 亚洲大片在线观看| 欧美一区二区三区在线播放| 最新精品在线| 久久躁狠狠躁夜夜爽| 国产精品v日韩精品| 99热免费精品在线观看| 久久香蕉国产线看观看网| 午夜精品福利一区二区三区av| 亚洲狼人精品一区二区三区| 久久久蜜桃精品| 国产一区二区激情| 欧美亚洲第一区| 99视频精品免费观看| 欧美刺激性大交免费视频| 久久国产精品第一页| 国产亚洲欧美日韩日本| 欧美怡红院视频| 午夜日韩视频| 国产午夜精品全部视频在线播放 | 久久综合给合久久狠狠色 | 怡红院精品视频| 久久九九国产精品| 欧美尤物巨大精品爽| 国产精品综合不卡av| 久久av一区| 久久久久看片| aa日韩免费精品视频一| 99精品国产99久久久久久福利| 欧美三区美女| 欧美在线观看一区| 久久久久久久久久久久久女国产乱 | 欧美日韩另类国产亚洲欧美一级| 亚洲一区二区在线播放| 亚洲在线免费视频| 国产日韩欧美亚洲一区| 蜜臀av性久久久久蜜臀aⅴ| 免费成人激情视频| 在线一区日本视频| 欧美一区二区三区四区夜夜大片| 精品99一区二区| 夜夜嗨av色综合久久久综合网| 国产午夜精品在线| 亚洲国产一区二区三区在线播| 欧美日韩亚洲激情| 欧美伊人久久| 男人插女人欧美| 亚洲欧美精品伊人久久| 欧美专区日韩专区| 国产亚洲欧美日韩日本| 亚洲毛片播放| 国产免费成人| 免费国产自线拍一欧美视频| 美女久久一区| 亚洲午夜久久久久久久久电影网| 一区二区三区欧美在线| 国产视频一区二区在线观看| 老**午夜毛片一区二区三区| 欧美成人首页| 性欧美大战久久久久久久免费观看 | 一本色道久久88综合日韩精品| 99这里只有久久精品视频| 国产精品久久久久久久浪潮网站 | 亚洲欧美日韩中文在线制服| 午夜在线精品偷拍| 亚洲免费观看高清完整版在线观看熊| 亚洲在线网站| 欧美日韩国产综合视频在线观看中文| 国产主播一区二区三区| 午夜久久影院| 蜜臀久久99精品久久久画质超高清 | 亚洲视频一二三| 欧美人交a欧美精品| 亚洲高清免费| 美女精品一区| 久久精品国产一区二区三区免费看| 欧美午夜一区二区三区免费大片 | 欧美日韩国产成人在线观看| 最近中文字幕日韩精品 | 久久综合色一综合色88| 国内精品久久久久久影视8| 欧美一区1区三区3区公司| 免费在线一区二区| 亚洲制服欧美中文字幕中文字幕| 欧美日韩精品二区| 在线视频一区二区| 在线综合亚洲欧美在线视频| 欧美日韩在线视频首页| 亚洲国产一区二区三区高清| 日韩亚洲欧美成人| 国产精品videosex极品| 新67194成人永久网站| 亚洲综合视频一区| 国内成+人亚洲+欧美+综合在线| 久久www成人_看片免费不卡| 欧美一区二区三区的| 韩国女主播一区二区三区| 蜜桃久久精品乱码一区二区| 欧美a级片一区| 午夜精品久久久久久久99樱桃| 欧美日韩三级视频| 亚洲国产精品久久久久婷婷884 | 欧美高清一区| 国产一区二区剧情av在线| 99re8这里有精品热视频免费 | 亚洲精品日韩精品| 91久久精品国产91性色| 国产精品99久久久久久宅男| 亚洲欧美激情一区二区| 99re视频这里只有精品| 美日韩精品视频| 久久先锋影音| 国产日本亚洲高清| 亚洲欧美综合一区| 久久国产88| 国产真实久久| 久久久久国产精品午夜一区| 老色批av在线精品| 亚洲成色精品| 欧美国产激情| 亚洲精品美女91| 一区二区三区视频在线观看 | 最新亚洲一区| 欧美极品色图| 亚洲人成网站999久久久综合| 日韩视频在线观看一区二区| 欧美日韩高清区| 亚洲视频在线视频| 欧美在线免费观看视频| 韩日欧美一区二区三区| 久热精品视频在线观看一区| 欧美不卡一区| 亚洲精品美女免费| 久久久欧美精品sm网站| 欧美大尺度在线观看| 亚洲无限乱码一二三四麻| 国产精品日韩久久久| 香蕉成人伊视频在线观看| 久久婷婷丁香| 亚洲精品久久久蜜桃| 欧美日韩视频免费播放| 亚洲在线免费视频| 欧美不卡在线| 亚洲欧美福利一区二区| 国产精品男人爽免费视频1| 欧美在线亚洲| 亚洲精品免费电影| 欧美一区二区三区免费观看视频| 亚洲高清免费| 国产精品亚洲综合一区在线观看| 久久夜色精品国产欧美乱| 亚洲精品美女在线| 久久一区二区三区av| 一区二区三区 在线观看视| 一区二区三区四区五区视频| 久久九九热免费视频| 久久一区二区精品| 韩日精品在线| 免费欧美日韩| 开心色5月久久精品| 一本到高清视频免费精品| 欧美日韩一区二区三区在线| 亚洲欧美精品在线观看| 亚洲网站在线观看| 亚洲日本电影在线| 欧美三区美女| 欧美第十八页| 欧美一级二区| 激情久久影院| 欧美日韩精品久久| 一区二区三区毛片| 在线观看欧美日本| 欧美视频一区二区| 欧美中文字幕不卡| 亚洲国产成人porn| 久久经典综合| 最近中文字幕mv在线一区二区三区四区 | 亚洲激情中文1区| 欧美经典一区二区三区| 国产精品99久久久久久久女警| 亚洲欧美一区二区在线观看| 国产精品久久久久久久久久久久| 亚洲一区二区成人| 美女成人午夜| 亚洲综合清纯丝袜自拍| 国产精品黄视频| 久久精品国语| 亚洲欧洲一区二区三区在线观看| 久久综合伊人77777麻豆| 久久精品在线播放| 亚洲一区二区不卡免费| 国内外成人在线| 欧美人与性动交a欧美精品| 亚洲曰本av电影| 亚洲第一网站免费视频| 久久精品国产精品| 亚洲成人影音|