任务分配问题:公共调度,单独执行 贪心 C++

问题描述:一个公司下面有n个部门,现在要给每个部门分配任务,分配任务只能按照分配的顺序进行,不能同时分配两个任务,只能一个接一个的分配,但是分配完任务后,该部门可以立刻执行(不间断),分配一个任务的时间是a,执行一个任务的时间是b,你需要做的就是决定分配给每一个部门的任务的顺序,使得所有的部门完成任务的总时间最短。

 

思路:贪心策略。因为分配时只有一个部门负责,可以想象,分配部门的工作是不间断的,给第一个任务分配完,就要继续给第二个任务分配,他的工作时间从开始,一直到所有的工作都分配结束,分配部门停止工作的时间是所有工作的分配时间之和。每个任务必须要在分配结束之后才能执行。所以,由于分配的总时间是固定的,所以就是看最后的执行时间,所以要尽可能地让执行时间长的任务先分配,类似于多处最优服务次序问题。

 

代码如下:

work中,a代表分配时间,b代表执行时间。

at数组记录每个任务的分配时间,如at[2]代表任务2的分配结束时间。bt[2]代表任务2的执行结束时间。最后,在bt中遍历求得最大值,即为最小的任务完成时间。

#include<bits/stdc++.h>
using namespace std;
/*
3
2 2
3 4
1 5
3
2 4
4 2
3 3

*/
struct work{
	int a;
	int b;
};
bool cmp(work x,work y){
	if(x.b!=y.b) return x.b>y.b;
	else 
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
多机调度问题是一个经典的优化问题,其目标是将一组任务分配给多台机器,使得任务的完成时间最小化。贪心算法是解决多机调度问题的一种常用方法。 在贪心算法中,我们通过每次选择当前最优的任务来构建解决方案。对于多机调度问题,可以按照以下步骤进行贪心算法的设计: 1. 将任务按照其执行时间从大到小进行排序。 2. 创建一个长度为机器数量的数组,用于记录每台机器的当前任务执行时间。 3. 遍历排序后的任务列表,将每个任务分配给当前执行时间最小的机器,并更新该机器的执行时间。 4. 返回所有机器中执行时间最长的值作为最终的完成时间。 以下是一个使用C++实现的多机调度问题贪心算法示例: ```cpp #include <iostream> #include <vector> #include <algorithm> using namespace std; int greedyMultiMachineScheduling(vector<int>& tasks, int numMachines) { sort(tasks.rbegin(), tasks.rend()); // 按照执行时间从大到小排序 vector<int> machineTimes(numMachines, 0); // 记录每台机器的当前任务执行时间 for (int task : tasks) { int minTime = machineTimes; int minIndex = 0; // 找到当前执行时间最小的机器 for (int i = 1; i < numMachines; i++) { if (machineTimes[i] < minTime) { minTime = machineTimes[i]; minIndex = i; } } // 将任务分配给当前执行时间最小的机器,并更新执行时间 machineTimes[minIndex] += task; } // 返回所有机器中执行时间最长的值作为最终的完成时间 return *max_element(machineTimes.begin(), machineTimes.end()); } int main() { vector<int> tasks = {3, 2, 4, 1, 5}; int numMachines = 3; int completionTime = greedyMultiMachineScheduling(tasks, numMachines); cout << "完成时间:" << completionTime << endl; return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值