任务分配问题(回溯法)

算法设计

问题描述

有n(n≥1)个任务需要分配给n个人执行,每个任务只能分配给一个人,每个人只能执行一个任务。

第i个人执行第j个任务的成本是c[i][j](1≤i,j≤n)。求出总成本最小的分配方案

解题思路

回溯法解题的一般步骤

(1)针对给定的问题确定问题的解空间树,问题的解空间树应至少包含问题的一个解或者最优解。

(2)确定结点的扩展搜索规则

(3)以深度优先的方式搜索解空间树,并在搜索的过程中可以采用减枝函数来避免无效搜索。其中,深度优先方式可以选择递归回溯或者迭代(非递归)回溯

通过将问题进行适当的转化,得出解空间树为排列树,这棵树每条完整路径都代表了一种解的可能。通过深度优先搜索这棵树,枚举每种可能的解的情况,找出能得到最小的花费结果。其中构造约束函数,可以删除一些不可能的解,从而大大提高程序效率

算法描述

(1)解空间

解空间为{x1,x2,x3,x4......,xn},其中xi=1,2,3,4......n,表示第i个人安排的任务

(2)解空间树


c 复制代码
#include<stdio.h>
#include<cstring>
#include<queue>

using namespace std;
#define MAXN 20		
#define INF 9999
//问题表示: 
int n=4;//人或任务个数 
int c[MAXN][MAXN]={{0,0,0,0,0},{0,9,2,7,8},{0,6,4,3,7},{0,5,8,1,8},{0,7,6,9,4}}; 
//求解结果表示: 
int x[MAXN]; 		//临时解
int cost=0;			//临时解的成本
int bestx[MAXN];	//最优解
int mincost=INF;	//最优解成本
bool worker[MAXN]; 	//表示任务是否已经分配人员 

void dfs(int i)		//为第i个人员分配任务 
{
	if(i>n)			//如果达到叶子节点 
	{
		if(cost<mincost)		//当前成本小于最小成本mincost
		{mincost=cost;			//更新最小成本
		for(int j=1;j<=n;j++)	//遍历所有人员编号1~n
			bestx[j]=x[j];		//将最佳人员编号给bestx
		}
	}
	else{
		for(int j=1;j<=n;j++)	//遍历所有人员编号1~n
		if(!worker[j])			//如果没有分配任务
		{
		worker[j]=true;			//标记已经分配任务
		x[i]=j;					//将任务编号j分配给第i个人
		cost+=c[i][j];			//更新成本,加上分配任务成本
		dfs(i+1);				//调用dfs函数,分配下一个人员
		worker[j]=false;		//标记该人员未分配任务
		x[j]=0;					//任务编号清零,表示该人员未被分配任务
		cost-=c[i][j];			//更新当前成本,减去分配任务成本
	} 
 } 
}
int  main()
 {
 	memset(worker,0,sizeof(worker));				//memset函数将worker数组的所有元素初始化为0。
 	dfs(1);											//寻找最优方案
 	printf("最优方案\n");
 	for(int k=1;k<=n;k++)							//从1循环到总人数n
 		printf("第%d个人安排任务%d\n",k,bestx[k]);	//输出第k个人的任务分配
 	printf("总成本=%d\n",mincost);					//输出最小成本
 	return 0;
 }
相关推荐
Coovally AI模型快速验证4 分钟前
农田扫描提速37%!基于检测置信度的无人机“智能抽查”路径规划,Coovally一键加速模型落地
深度学习·算法·yolo·计算机视觉·transformer·无人机
pusue_the_sun7 分钟前
数据结构:二叉树oj练习
c语言·数据结构·算法·二叉树
RaymondZhao341 小时前
【全面推导】策略梯度算法:公式、偏差方差与进化
人工智能·深度学习·算法·机器学习·chatgpt
zhangfeng11331 小时前
DBSCAN算法详解和参数优化,基于密度的空间聚类算法,特别擅长处理不规则形状的聚类和噪声数据
算法·机器学习·聚类
啊阿狸不会拉杆2 小时前
《算法导论》第 32 章 - 字符串匹配
开发语言·c++·算法
小学生的信奥之路2 小时前
洛谷P3817题解:贪心算法解决糖果分配问题
c++·算法·贪心算法
你知道网上冲浪吗3 小时前
【原创理论】Stochastic Coupled Dyadic System (SCDS):一个用于两性关系动力学建模的随机耦合系统框架
python·算法·数学建模·数值分析
地平线开发者4 小时前
征程 6 | PTQ 精度调优辅助代码,总有你用得上的
算法·自动驾驶
Tisfy5 小时前
LeetCode 837.新 21 点:动态规划+滑动窗口
数学·算法·leetcode·动态规划·dp·滑动窗口·概率
CoovallyAIHub5 小时前
为高空安全上双保险!无人机AI护航,YOLOv5秒判安全带,守护施工生命线
深度学习·算法·计算机视觉