栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

多级调度(贪心算法)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

多级调度(贪心算法)

#include
#include
#include 
#include
using namespace std;

struct TJob//作业
{
	int id;//索引号
	int t;//用时
};
bool operator>(const TJob& x, const TJob& y)
	{
		return x.t > y.t;
	}
struct TM//机器
{
	int id;
	int t;
	vectorVJ;
	TM() :id(0),t(0) {}
};
struct TMInQ//机器在优先队列中的数据结构
{
	int id;
	int t;
	
};
bool operator>(const TMInQ& x,const TMInQ& y)
{
	return x.t > y.t;
}
int main()
{
	int n, m;
	cout << "请依次输入作业个数和机器个数"<> n >> m;
	TJob* J = new TJob[n];
	for (int i = 0; i < n; i++)
	{
		J[i].id = i+1;//作业编号从1开始到n
		cout << "作业" << J[i].id << "的用时为:";
		cin >> J[i].t;//赋值
	}
	TM* M = new TM[m];
	for (int i = 0; i < m; i++)
	{
		M[i].id = i ;//机器在数组中的下标
		M[i].t = 0;
		//VJ不用管,默认为空
	}
	priority_queue, greater >PQ;
		sort(J, J + n, greater());
	for (int i = 0; i < m; i++)
	{
		M[i].t = J[i].t;
		M[i].VJ.push_back(J[i].id);
		TMInQ ma;
		ma.id = M[i].id;
		ma.t = M[i].t;
		PQ.push(ma);
	}
	//贪心策略求解
	for (int i = m; i < n; i++)
	{
		TMInQ ma = PQ.top();
		PQ.pop();
		//ma.id就是当前需要分配任务的机器
		M[ma.id].t += J[i].t;
		M[ma.id].VJ.push_back(J[i].id);
		ma.t += J[i].t;
		PQ.push(ma);
	}
	//输出解
	for (int i = 0; i < m; i++)
	{
		cout << "机器" << M[i].id+1 << "处理作业";
		for (int j = 0; j < M[i].VJ.size(); j++)
		{
			cout << M[i].VJ[j] << ",";//打印作业标号
		}
		cout << "总用时为"< 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/862711.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号