亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? 000.cpp

?? 運(yùn)籌學(xué)之指派問(wèn)題的匈牙利算法。 運(yùn)籌學(xué)上的一個(gè)經(jīng)典算法
?? CPP
字號(hào):
/**********************************************************************\
*                    指派問(wèn)題的匈牙利算法                              *
*                                                                      *
*                         張志亮                                       *
*                                                                      *
*                                                                      *
*                                                                      * 
*                                                                      *
*               河海大學(xué)商學(xué)院信息管理與信息系統(tǒng)專(zhuān)業(yè)                   *
*                                                                      *
*                                                                      *
\**********************************************************************/






#include<stdio.h>

typedef struct matrix
{
	float cost[101][101];
    int zeroelem[101][101];
	float costforout[101][101];
	int matrixsize;
	int personnumber;
	int jobnumber;
}matrix;

matrix sb;
int result[501][2];

void twozero(matrix &sb);
void judge(matrix &sb,int result[501][2]);
void refresh(matrix &sb);
void circlezero(matrix &sb);
matrix input();
void output(int result[501][2],matrix sb);
void zeroout(matrix &sb);






matrix input()
{
	matrix sb;
	int m;
	int pnumber,jnumber;
	int i,j;
	float k;
	char w;
	printf("指派問(wèn)題的匈牙利解法:\n");
	printf("max,請(qǐng)輸入1;min,請(qǐng)輸入0:\n");
	scanf("%d",&m);
	while (m!=1&&m!=0)
	{	
		printf("請(qǐng)輸入1或0:\n");
		scanf("%d",&m);
	}
	printf("請(qǐng)輸入人數(shù)(人數(shù)介于1和100之間):\n");
	scanf("%d",&pnumber);
	while(pnumber<1 || pnumber>100)
	{
		printf("請(qǐng)輸入合法數(shù)據(jù):\n");
		scanf("%d",&pnumber);
	}
	printf("請(qǐng)輸入工件數(shù)(介于1和100之間):\n");
	scanf("%d",&jnumber);
	while(jnumber<1 || jnumber>100)
	{
		printf("請(qǐng)輸入合法數(shù)據(jù):\n");
		scanf("%d",&jnumber);
	}
	printf("請(qǐng)輸入%d行%d列的矩陣,同一行內(nèi)以空格間隔,不同行間以回車(chē)分隔:\n",pnumber,jnumber);
	for(i=1;i<=pnumber;i++)
		for(j=1;j<=jnumber;j++)
		{
			scanf("%f",&sb.cost[i][j]);
			sb.costforout[i][j]=sb.cost[i][j];
		}
	scanf("%c",&w);        //吸收回車(chē)符
	if(jnumber>pnumber)
		for(i=pnumber+1;i<=jnumber;i++)
			for(j=1;j<=jnumber;j++)
			{
				sb.cost[i][j]=0;
				sb.costforout[i][j]=0;
			}
	else
	{
		if(pnumber>jnumber)
			for(i=1;i<=pnumber;i++)
				for(j=jnumber+1;j<=pnumber;j++)
				{
					sb.cost[i][j]=0;
					sb.costforout[i][j]=0;
				}

	}
	sb.matrixsize=pnumber;
	if(pnumber<jnumber)
		sb.matrixsize=jnumber;
	sb.personnumber=pnumber;
	sb.jobnumber=jnumber;
	if(m==1)
	{
		k=0;
		for(i=1;i<=sb.matrixsize;i++)
			for(j=1;j<=sb.matrixsize;j++)
				if(sb.cost[i][j]>k)
					k=sb.cost[i][j];
		for(i=1;i<=sb.matrixsize;i++)
			for(j=1;j<=sb.matrixsize;j++)
				sb.cost[i][j]=k-sb.cost[i][j];
	}
	return sb;
}//input


void circlezero(matrix &sb)
{
	int i,j;
	float k;
	int p;
	for(i=0;i<=sb.matrixsize;i++)
		sb.cost[i][0]=0;
	for(j=1;j<=sb.matrixsize;j++)
		sb.cost[0][j]=0;
	for(i=1;i<=sb.matrixsize;i++)
		for(j=1;j<=sb.matrixsize;j++)
			if(sb.cost[i][j]==0)
			{
				sb.cost[i][0]++;
				sb.cost[0][j]++;
				sb.cost[0][0]++;
			}
	for(i=0;i<=sb.matrixsize;i++)
		for(j=0;j<=sb.matrixsize;j++)
			sb.zeroelem[i][j]=0;
	  
	k=sb.cost[0][0]+1;
	while(sb.cost[0][0]<k)
	{
		k=sb.cost[0][0];
		for(i=1;i<=sb.matrixsize;i++)
		{
			if(sb.cost[i][0]==1)
			{
				for(j=1;j<=sb.matrixsize;j++)
					if(sb.cost[i][j]==0&&sb.zeroelem[i][j]==0)
						break;
				sb.zeroelem[i][j]=1;
				sb.cost[i][0]--;
				sb.cost[0][j]--;
				sb.cost[0][0]--;
				if(sb.cost[0][j]>0)
					for(p=1;p<=sb.matrixsize;p++)
						if(sb.cost[p][j]==0&&sb.zeroelem[p][j]==0)
						{
							sb.zeroelem[p][j]=2;
							sb.cost[p][0]--;
							sb.cost[0][j]--;
							sb.cost[0][0]--;
						}
			}
		}
		for(j=1;j<=sb.matrixsize;j++)
		{
			if(sb.cost[0][j]==1)
			{
				for(i=1;i<=sb.matrixsize;i++)
					if(sb.cost[i][j]==0&&sb.zeroelem[i][j]==0)
						break;
				sb.zeroelem[i][j]=1;
				sb.cost[i][0]--;
				sb.cost[0][j]--;
				sb.cost[0][0]--;
				if(sb.cost[i][0]>0)
					for(p=1;p<=sb.matrixsize;p++)
						if(sb.cost[i][p]==0&&sb.zeroelem[i][p]==0)
						{
							sb.zeroelem[i][p]=2;
							sb.cost[i][0]--;
							sb.cost[0][p]--;
							sb.cost[0][0]--;
						}
			}
		}
	}//while
	if(sb.cost[0][0]>0)
		twozero(sb);
	else
		judge(sb,result);
}//circlezero


void twozero(matrix &sb)
{
	int i,j;
	int p,q;
	int m,n;
	float k;
    matrix st;
	for(i=1;i<=sb.matrixsize;i++)
		if(sb.cost[i][0]>0)
			break;
	if(i<=sb.matrixsize)
	{
		for(j=1;j<=sb.matrixsize;j++)
		{
			st=sb;//pay attention
			if(sb.cost[i][j]==0&&sb.zeroelem[i][j]==0)
			{
				sb.zeroelem[i][j]=1;
				sb.cost[i][0]--;
				sb.cost[0][j]--;
				sb.cost[0][0]--;
				for(q=1;q<=sb.matrixsize;q++)
					if(sb.cost[i][q]==0&&sb.zeroelem[i][q]==0)
					{
						sb.zeroelem[i][q]=2;
						sb.cost[i][0]--;
						sb.cost[0][q]--;
						sb.cost[0][0]--;
					}
				for(p=1;p<=sb.matrixsize;p++)
					if(sb.cost[p][j]==0&&sb.zeroelem[p][j]==0)
					{
						sb.zeroelem[p][j]=2;
						sb.cost[p][0]--;
						sb.cost[0][j]--;
						sb.cost[0][0]--;
					}

				k=sb.cost[0][0]+1;
				while(sb.cost[0][0]<k)
				{
					k=sb.cost[0][0];
					for(p=i+1;p<=sb.matrixsize;p++)
					{
						if(sb.cost[p][0]==1)
						{
							for(q=1;q<=sb.matrixsize;q++)
								if(sb.cost[p][q]==0&&sb.zeroelem[p][q]==0)
									break;
							sb.zeroelem[p][q]=1;
							sb.cost[p][0]--;
							sb.cost[0][q]--;
							sb.cost[0][0]--;
							for(m=1;m<=sb.matrixsize;m++)
								if(sb.cost[m][q]=0&&sb.zeroelem[m][q]==0)
								{
									sb.zeroelem[m][q]=2;
									sb.cost[m][0]--;
									sb.cost[0][q]--;
									sb.cost[0][0]--;
								}
						}//if
					}//for
					for(q=1;q<=sb.matrixsize;q++)
					{
						if(sb.cost[0][q]==1)
						{
							for(p=1;p<=sb.matrixsize;p++)
								if(sb.cost[p][q]==0&&sb.zeroelem[p][q]==0)
									break;
							sb.zeroelem[p][q]=1;
							sb.cost[p][q]--;
							sb.cost[0][q]--;
							sb.cost[0][0]--;
							for(n=1;n<=sb.matrixsize;n++)
								if(sb.cost[p][n]==0&&sb.zeroelem[p][n]==0)
								{
									sb.zeroelem[p][n]=2;
									sb.cost[p][0]--;
									sb.cost[0][n]--;
									sb.cost[0][0]--;
								}
						}//if
					}//for
				}//while
				if(sb.cost[0][0]>0)
					twozero(sb);
				else 
					judge(sb,result);
			}//if->p5	          
			sb=st;
		}//for->p5
	}//if->p5
}//twozero


void judge(matrix &sb,int result[501][2])
{
	int i,j;
	int m;
	int n;
	int k;
	m=0;
	for(i=1;i<=sb.matrixsize;i++)
		for(j=1;j<=sb.matrixsize;j++)
			if(sb.zeroelem[i][j]==1)
				m++;
	if(m==sb.matrixsize)
	{
		k=1;
		for(n=1;n<=result[0][0];n++)
		{
			for(i=1;i<=sb.matrixsize;i++)
			{
				for(j=1;j<=sb.matrixsize;j++)
					if(sb.zeroelem[i][j]==1)
						break;
				if(i<=sb.personnumber&&j<=sb.jobnumber)
					if(j!=result[k][1])
						break;
				k++;
			}
			if(i==sb.matrixsize+1)
				break;
			else
				k=n*sb.matrixsize+1;
		}
		if(n>result[0][0])
		{
			k=result[0][0]*sb.matrixsize+1;
			for(i=1;i<=sb.matrixsize;i++)
				for(j=1;j<=sb.matrixsize;j++)
					if(sb.zeroelem[i][j]==1)
					{
						result[k][0]=i;
						result[k++][1]=j;
					}
			result[0][0]++;
		}
	}
	else
	{
		refresh(sb);
	}
}//judge


void refresh(matrix &sb)
{
	int i,j;
	float k;
	int p;
	k=0;

	for(i=1;i<=sb.matrixsize;i++)
	{
		for(j=1;j<=sb.matrixsize;j++)
			if(sb.zeroelem[i][j]==1)
			{
				sb.zeroelem[i][0]=1;         //有獨(dú)立零元素
				break;
			}
	}
	while(k==0)
	{
		k=1;
		for(i=1;i<=sb.matrixsize;i++)
			if(sb.zeroelem[i][0]==0)
			{
				sb.zeroelem[i][0]=2;
				for(j=1;j<=sb.matrixsize;j++)
					if(sb.zeroelem[i][j]==2)
					{
						sb.zeroelem[0][j]=1;
					}
			}
		for(j=1;j<=sb.matrixsize;j++)
		{
			if(sb.zeroelem[0][j]==1)
			{
				sb.zeroelem[0][j]=2;
				for(i=1;i<=sb.matrixsize;i++)
					if(sb.zeroelem[i][j]==1)
					{
						sb.zeroelem[i][0]=0;
						k=0;
					}
			}
		}
	}                    //為2的行或者列是打"√"的
	p=0;
	k=0;
	for(i=1;i<=sb.matrixsize;i++)
	{
		if(sb.zeroelem[i][0]==2)
		{
			for(j=1;j<=sb.matrixsize;j++)
			{
				if(sb.zeroelem[0][j]!=2)
					if(p==0)
					{
						k=sb.cost[i][j];
						p=1;
					}
					else
					{
						if(sb.cost[i][j]<k)
							k=sb.cost[i][j];
					}
			}
		}
	}
	for(i=1;i<=sb.matrixsize;i++)
	{
		if(sb.zeroelem[i][0]==2)
			for(j=1;j<=sb.matrixsize;j++)
				sb.cost[i][j]=sb.cost[i][j]-k;
	}

	for(j=1;j<=sb.matrixsize;j++)
	{
		if(sb.zeroelem[0][j]==2)
			for(i=1;i<=sb.matrixsize;i++)
				sb.cost[i][j]=sb.cost[i][j]+k;
	}                                 //化簡(jiǎn)矩陣
	for(i=0;i<=sb.matrixsize;i++)
		for(j=0;j<=sb.matrixsize;j++)
			sb.zeroelem[i][j]=0;              //清0
	circlezero(sb);	
}//refresh


void zeroout(matrix &sb)
{
	int i,j; 
	float k;
	for(i=1;i<=sb.matrixsize;i++)
	{
		k=sb.cost[i][1];
		for(j=2;j<=sb.matrixsize;j++)
			if(sb.cost[i][j]<k)
				k=sb.cost[i][j];
		for(j=1;j<=sb.matrixsize;j++)
			sb.cost[i][j]=sb.cost[i][j]-k;
	}
	for(j=1;j<=sb.matrixsize;j++)
	{
		k=sb.cost[1][j];
		for(i=2;i<=sb.matrixsize;i++)
			if(sb.cost[i][j]<k)
				k=sb.cost[i][j];
		for(i=1;i<=sb.matrixsize;i++)
			sb.cost[i][j]=sb.cost[i][j]-k;
	}
}//zeroout


void output(int result[501][2],matrix sb)
{
	int k;
	int i;
	int j;
	int p;
	char w;
	float v;

	v=0;
	for(i=1;i<=sb.matrixsize;i++)
	{
		v=v+sb.costforout[i][result[i][1]];
	}
	printf("最優(yōu)解的目標(biāo)函數(shù)值為%f.\n",v);

	k=result[0][0];
	if(k>5)
	{
		printf("解的個(gè)數(shù)超過(guò)了限制.\n");
		k=5;
	}
	for(i=1;i<=k;i++)
	{
		printf("按任意鍵輸出第%d種解.\n",i);
		scanf("%c",&w);
		p=(i-1)*sb.matrixsize+1;
		for(j=p;j<p+sb.matrixsize;j++)
			if(result[j][0]<=sb.personnumber&&result[j][1]<=sb.jobnumber)
				printf("第%d個(gè)人做第%d件工作.\n",result[j][0],result[j][1]);
		printf("\n");
	}
}//output


void main()
{
	result[0][0]=0;
	sb=input();
	zeroout(sb);
	circlezero(sb);
	output(result,sb);
}//main

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久影院午夜论| 亚洲视频一二区| 精品国产乱码久久久久久闺蜜| 欧美精品 日韩| 欧美男男青年gay1069videost| 国产精品久久久久7777按摩| 欧美中文字幕一区二区三区| 亚洲午夜羞羞片| 国产精品美女久久久久av爽李琼| 国产91丝袜在线播放0| 亚洲国产视频直播| 午夜国产精品影院在线观看| 日韩在线a电影| 成人国产精品免费观看动漫| 色婷婷av一区| 精品久久久久香蕉网| 久久综合五月天婷婷伊人| 日本一区二区三级电影在线观看| 91九色最新地址| 欧美精品一区二区蜜臀亚洲| 国产精品国产a| 日产欧产美韩系列久久99| 国产福利一区二区三区| 欧美视频中文一区二区三区在线观看| 国模少妇一区二区三区| 91福利国产精品| 国产精品免费丝袜| 天天做天天摸天天爽国产一区 | 69精品人人人人| 国产精品麻豆视频| 日本亚洲视频在线| 在线观看免费一区| 国产精品妹子av| 国产成人av影院| 欧美一区午夜视频在线观看| 国产精品网站一区| 国产麻豆视频一区二区| 91精品国产入口| 日本女人一区二区三区| 欧美色精品在线视频| 1000精品久久久久久久久| 国产精品一区免费在线观看| 日韩久久久久久| 久久不见久久见免费视频1| 日韩一区二区三区免费看| 视频一区视频二区中文字幕| 欧美日韩一区不卡| 亚洲成av人片www| 欧美一区二区大片| 免费在线看一区| 久久久精品免费免费| 国产高清一区日本| 欧美亚洲综合在线| 五月激情综合婷婷| 精品国产91乱码一区二区三区| 日韩女优av电影| 免费看日韩a级影片| 久久欧美一区二区| 99精品国产99久久久久久白柏 | 久久―日本道色综合久久| 麻豆精品一区二区三区| 精品国产乱码久久| 久久99精品久久久久久国产越南| 国产三级精品三级在线专区| 国产老女人精品毛片久久| 日本一区二区视频在线观看| 91在线视频播放地址| 亚洲国产欧美另类丝袜| 欧美成人官网二区| 国产高清视频一区| 亚洲精品自拍动漫在线| 欧美一区二区视频免费观看| 国产精品1区二区.| 一区二区视频在线| 久久久久久久一区| 欧美性色综合网| 99综合电影在线视频| 亚洲综合久久久| 国产人成一区二区三区影院| 欧美日本乱大交xxxxx| 从欧美一区二区三区| 理论电影国产精品| 亚洲最大成人网4388xx| 欧美韩国日本不卡| 日韩情涩欧美日韩视频| 欧美最新大片在线看| 91在线播放网址| 国产91清纯白嫩初高中在线观看| 777xxx欧美| 91亚洲精华国产精华精华液| 国产激情精品久久久第一区二区| 91精品免费在线观看| 91免费国产在线| 成人国产免费视频| 岛国一区二区三区| 国产激情视频一区二区在线观看| 欧美一区二区三区色| 欧美日韩一区二区电影| 欧美在线|欧美| 99久久精品国产精品久久| 国产真实乱子伦精品视频| 捆绑调教一区二区三区| 免费观看一级特黄欧美大片| 视频一区二区三区中文字幕| 亚洲国产日产av| 偷窥少妇高潮呻吟av久久免费| 日韩一区二区在线看| 精品久久久久香蕉网| 成人午夜视频在线观看| 成人一级片网址| av资源网一区| 欧美精品乱码久久久久久| 日韩一级片在线观看| 久久久精品日韩欧美| 国产精品久久久久久亚洲伦| 中文字幕色av一区二区三区| 亚洲人成精品久久久久| 亚洲v日本v欧美v久久精品| 蜜臀久久99精品久久久久宅男 | 亚洲成国产人片在线观看| 日本人妖一区二区| 国产激情精品久久久第一区二区| 亚洲天堂久久久久久久| 亚洲国产精品视频| 韩国女主播一区| 99久久精品一区二区| 欧美日韩一区中文字幕| 99精品视频在线观看| 国产成人av电影在线| 色天天综合色天天久久| 精品国产免费久久| 中文字幕在线观看一区| 蜜桃一区二区三区在线观看| 成人中文字幕电影| 精品国精品国产尤物美女| 国产精品久久久久久久第一福利 | 51精品秘密在线观看| 综合电影一区二区三区 | 亚洲精选视频在线| 国产尤物一区二区在线| 欧美色老头old∨ideo| 国产欧美一区二区精品性| 日韩精品一卡二卡三卡四卡无卡| 日本一二三不卡| 人人精品人人爱| 欧美一a一片一级一片| 亚洲日本乱码在线观看| 菠萝蜜视频在线观看一区| 国产喷白浆一区二区三区| 老汉av免费一区二区三区| 欧美一级二级在线观看| 五月激情综合色| 欧美日韩高清一区二区不卡| 亚洲在线中文字幕| 欧美在线观看禁18| 亚洲第一狼人社区| 欧美在线免费观看视频| 亚洲男人的天堂网| 在线影院国内精品| 性做久久久久久免费观看| 91精品国产日韩91久久久久久| 精品欧美一区二区三区精品久久| 国产一区二区免费在线| 91精品蜜臀在线一区尤物| 亚洲午夜视频在线观看| 日韩免费看网站| 精品午夜久久福利影院| 久久久亚洲精品石原莉奈| www.亚洲在线| 亚洲一区二区不卡免费| 日韩欧美国产不卡| 粉嫩13p一区二区三区| 一区二区在线观看不卡| 日韩一级大片在线| 成人网在线免费视频| 午夜久久久久久电影| 精品国产91乱码一区二区三区| 中文字幕精品—区二区四季| 91毛片在线观看| 久久精品国产秦先生| 国产精品国模大尺度视频| 欧美美女视频在线观看| 国产精品18久久久久| 亚洲精品欧美专区| 久久精品夜色噜噜亚洲aⅴ| 欧美视频在线播放| 国产成人亚洲精品狼色在线| 午夜久久电影网| 国产片一区二区三区| 日韩一区二区三区高清免费看看 | 欧美不卡视频一区| 91美女精品福利| 国产激情一区二区三区四区| 日本成人在线不卡视频| 亚洲制服丝袜av| 日韩一区二区三区四区| 国产成人精品影视| 国产精品福利一区二区三区| 久久日韩精品一区二区五区| 欧美精品日韩一区|