C++贪心算法处理多机调度问题详解
多机调度问题思路
1、把作业按加工所用的时间从大到小排序
2、如果作业数目比机器的数目少或相等,则直接把作业分配下去
3、 如果作业数目比机器的数目多,则每台机器上先分配一个作业,如下的作业分配时,是选那个表头上 s 最小的链表加入新作业
可以考虑以下的贪心策略:
【C++贪心算法处理多机调度问题详解】(1)最长处理时间作业优先的贪心选择策略。
(2)最短处理时间作业优先的贪心选择策略。
(3)作业到达时间优先的贪心选择策略。
*贪?策略:优先处理花费时间长的任务,这样可以减少短任务的等待时间.
问题描述
形式:有n个任务,m台机器,n>m,每个作业i可以选择?台设备进?加?,加?时间为ti,每台机器同时只能加??个作业,且不可中断。实现作业调度,使得n个作业的等待时间最短。
假定有7个独立作业,所需处理时间分别为{2,14,4,16,6,5,3},由三台机器M1,M2,M3加工。按照贪心算法产生的作业调度如下图所示,所需总加工时间为17.
代码实现【C++】
#includeusing namespace std; #define N 7 #define M 3 int s[M] = { 0, 0, 0 }; //求出目前处理作业的时间和 最小的机器号 int min(int m){int min = 0; int i; for (i = 1; i s[i]){min = i; }}return min; }//求最终结果(最长处理时间) int max(int s[], int num){int max = s[0]; for (int i = 1; i
结果
![]()
文章图片
到此这篇关于C++贪心算法处理多机调度问题详解的文章就介绍到这了,更多相关C++多机调度内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 2022 开放原子全球开源峰会(开放原子算法大赛拉开帷幕)
- 汽车|聪明的“博弈算法”,体验极狐阿尔法S全新HI版高阶智能驾驶辅助
- Java实现拓扑排序算法的示例代码
- ACM学习|c++ STL 优先队列
- [数据结构]堆原理及其C++实现
- [GeekBand]|[GeekBand] C++面向对象高级编程-2
- 算法数据结构系列-实践篇-链表算法
- 【GeekBand】C++面向对象高级编程-第八周笔记
- PCA
- #|常用C/C++开源库