贪心算法——作业调度

简介: 贪心算法——作业调度

算法思想:长作业优先,先把作业分配给每台处理机,剩下的优先分配给先空闲的处理机。

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
struct job {
  int id;
  int costtime;
};
bool cmp(job a, job b) {
  return a.costtime > b.costtime;
}
int Greedy(vector<job> &j, int m) {
  int totle=0;//总花费时间
  vector <int>q(m, 0);
  sort(j.begin(),j.end(),cmp);
  //将作业按从大到小排列
  for (int i = 0; i < m; i++) {
    q[i] += j[i].costtime;
  }//将作业分配给所有空闲处理机
  for (int i = m; i <j.size(); i++) {
    int minPosition = min_element(q.begin(), q.end()) - q.begin();
    q[minPosition]+= j[i].costtime;
  }//将剩下作业分配给最先空闲的处理机
  totle = *max_element(q.begin(), q.end());
  return totle;
}
int main() {
  //输入作业数量
  int n;
  cin >> n;
  vector<job> j;
  for (int i = 0; i < n; i++) {
    job j1;
    j1.id = i;
    cin >> j1.costtime;
    j.push_back(j1);
  }
  cout<<Greedy(j, 3);
}
相关文章
|
3月前
|
机器学习/深度学习 算法 调度
基于NSGA-III算法求解微电网多目标优化调度研究(Matlab代码实现)
基于NSGA-III算法求解微电网多目标优化调度研究(Matlab代码实现)
163 3
|
3月前
|
机器学习/深度学习 运维 算法
基于非支配排序遗传算法NSGAII的综合能源优化调度(Matlab代码实现)
基于非支配排序遗传算法NSGAII的综合能源优化调度(Matlab代码实现)
258 0
基于非支配排序遗传算法NSGAII的综合能源优化调度(Matlab代码实现)
|
3月前
|
机器学习/深度学习 边缘计算 监控
【创新】【微电网多目标优化调度】五种多目标优化算法(MOJS、NSGA3、MOGWO、NSWOA、MOPSO)求解微电网多目标优化调度(Matlab代码实现)
【创新】【微电网多目标优化调度】五种多目标优化算法(MOJS、NSGA3、MOGWO、NSWOA、MOPSO)求解微电网多目标优化调度(Matlab代码实现)
260 0
|
3月前
|
机器学习/深度学习 运维 算法
【微电网多目标优化调度】多目标学习者行为优化算法MOLPB求解微电网多目标优化调度研究(Matlab代码实现)
【微电网多目标优化调度】多目标学习者行为优化算法MOLPB求解微电网多目标优化调度研究(Matlab代码实现)
222 1
|
3月前
|
机器学习/深度学习 算法 Java
基于灰狼优化算法(GWO)解决柔性作业车间调度问题(Matlab代码实现)
基于灰狼优化算法(GWO)解决柔性作业车间调度问题(Matlab代码实现)
239 1
|
3月前
|
供应链 算法 Java
【柔性作业车间调度问题FJSP】基于非支配排序的多目标小龙虾优化算法求解柔性作业车间调度问题FJSP研究(Matlab代码实现)
【柔性作业车间调度问题FJSP】基于非支配排序的多目标小龙虾优化算法求解柔性作业车间调度问题FJSP研究(Matlab代码实现)
137 1
|
3月前
|
运维 算法 搜索推荐
基于天牛须(BAS)与NSGA-Ⅱ混合算法的交直流混合微电网多场景多目标优化调度(Matlab代码实现)
基于天牛须(BAS)与NSGA-Ⅱ混合算法的交直流混合微电网多场景多目标优化调度(Matlab代码实现)
189 1
|
3月前
|
机器学习/深度学习 边缘计算 分布式计算
基于差分进化算法的微电网调度研究(Matlab代码实现)
基于差分进化算法的微电网调度研究(Matlab代码实现)
148 1
|
3月前
|
机器学习/深度学习 存储 算法
【微电网调度】考虑需求响应的基于改进多目标灰狼算法的微电网优化调度研究(Matlab代码实现)
【微电网调度】考虑需求响应的基于改进多目标灰狼算法的微电网优化调度研究(Matlab代码实现)
158 0
|
3月前
|
机器学习/深度学习 运维 算法
【复现】基于改进秃鹰算法的微电网群经济优化调度研究(Matlab代码实现)
【复现】基于改进秃鹰算法的微电网群经济优化调度研究(Matlab代码实现)
111 0

热门文章

最新文章