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

            pku2400 Supervisor, Supervisee 二分圖最優(yōu)匹配的全部解

            題意:
            給出職工對(duì)經(jīng)理的評(píng)分和經(jīng)理對(duì)職工的評(píng)分。求出所有的匹配方案,使得平均滿意度最高

            解法:
            KM匹配出最優(yōu)解后,根據(jù)標(biāo)號(hào)遍歷得所有解。注意,調(diào)整頂標(biāo)以后合法匹配邊仍然是l[i]+r[j]=val[i][j]

            代碼:

            Source Code

            Problem: 2400User: yzhw
            Memory: 408KTime: 0MS
            Language: G++Result: Accepted
            • Source Code
            • # include <cstdio>
              # include <cstring>
              # include <cstdlib>
              using namespace std;
              # define max(a,b) ((a)>(b)?(a):(b))
              # define min(a,b) ((a)<(b)?(a):(b))
              # define N 15
              int map[N][N],match[N],ln[N],rn[N],n,c;
              bool l[N],r[N];
              bool dfs(int pos)
              {
              	//if(l[pos]) return false;
              	l[pos]=true;
              	for(int i=0;i<n;i++)
              		if(!r[i]&&ln[pos]+rn[i]==map[pos][i])
              		{
              			r[i]=true;
              			if(match[i]==-1||dfs(match[i]))
              			{
              				match[i]=pos;
              				return true;
              			}
              
              		}
              		return false;
              }
              void adjust()
              {
              	int minnum=0xfffffff;
              	for(int i=0;i<n;i++)
              		if(l[i])
              			for(int j=0;j<n;j++)
              				if(!r[j])
              					minnum=min(minnum,ln[i]+rn[j]-map[i][j]);
              	for(int i=0;i<n;i++)
              	{
              		if(l[i]) ln[i]-=minnum;
              		if(r[i]) rn[i]+=minnum;
              	}
              }
              void search(int now)
              {
              	if(now==n)
              	{
              		int ret[N];
              		for(int i=0;i<n;i++)
              			ret[match[i]]=i;
              		printf("Best Pairing %d\n",++c);
              		for(int i=0;i<n;i++)
              			printf("Supervisor %d with Employee %d\n",i+1,ret[i]+1);
              		//system("pause");
              	}
              	for(int i=0;i<n;i++)
              		if(match[i]==-1&&ln[now]+rn[i]==map[now][i])
              		{
              			match[i]=now;
              			search(now+1);
              			match[i]=-1;
              		}
              }
              int main()
              {
              	int test;
              	scanf("%d",&test);
              	for(int tt=1;tt<=test;tt++)
              	{
              		scanf("%d",&n);
              		memset(map,0,sizeof(map));
              		for(int i=0;i<n;i++)
              			for(int j=0;j<n;j++)
              			{
              				int t;
              				scanf("%d",&t);
              				map[t-1][i]-=j;
              			}
              		for(int i=0;i<n;i++)
              			for(int j=0;j<n;j++)
              			{
              				int t;
              				scanf("%d",&t);
              				map[i][t-1]-=j;
              			}
              		
              		memset(match,-1,sizeof(match));
              		memset(rn,0,sizeof(rn));
              		for(int i=0;i<n;i++)
              		{
              			int maxnum=-0xfffffff;
              			for(int j=0;j<n;j++)
              				maxnum=max(maxnum,map[i][j]);
              			ln[i]=maxnum;
              		}
              		double ans=0;
              		for(int i=0;i<n;i++)
              		{
              			memset(l,false,sizeof(l));
              			memset(r,false,sizeof(r));
              			while(!dfs(i))
              			{
              				adjust();
              				memset(l,false,sizeof(l));
              				memset(r,false,sizeof(r));
              			}
              		}
              		for(int i=0;i<n;i++)
              			ans-=map[match[i]][i];
              		printf("Data Set %d, Best average difference: %.6f\n",tt,ans/n/2.0);
              		memset(match,-1,sizeof(match));
              		c=0;
              		search(0);
              		printf("\n");
              	}
              	return 0;
              }

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

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

            導(dǎo)航

            統(tǒng)計(jì)

            公告

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

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評(píng)論

            閱讀排行榜

            精品久久久久香蕉网| 国产精品免费久久久久电影网| 九九久久精品国产| 三级片免费观看久久| 99久久精品免费看国产一区二区三区 | 青青草原精品99久久精品66| 国产成人无码久久久精品一| 久久国产成人亚洲精品影院| 久久精品国产乱子伦| 国产成人香蕉久久久久| 亚洲精品无码成人片久久| 国产午夜精品理论片久久| 亚洲熟妇无码另类久久久| 久久精品国产福利国产琪琪| 久久精品国产亚洲av麻豆小说| 久久www免费人成精品香蕉| 久久久久无码精品国产| 久久久久久久久久久久久久| 亚洲综合精品香蕉久久网97| 少妇人妻88久久中文字幕| 婷婷久久综合九色综合绿巨人| 久久精品国产亚洲AV无码偷窥| 狠狠色丁香婷婷综合久久来来去 | 大伊人青草狠狠久久| 久久国内免费视频| 久久伊人色| 欧美精品福利视频一区二区三区久久久精品 | 色偷偷88888欧美精品久久久| 久久久久九国产精品| 99久久精品免费观看国产| 69SEX久久精品国产麻豆| 久久午夜伦鲁片免费无码| 一本久久a久久精品亚洲| 亚洲国产精品成人久久蜜臀| 久久久久久久久久免免费精品| 国产99久久久久久免费看| 93精91精品国产综合久久香蕉| 国产精品一区二区久久不卡| 97超级碰碰碰久久久久| 国产精品久久久久9999| 精品久久一区二区|