当前位置: 首页 > news >正文

口碑好的网站开发浙江坤宇建设有限公司 网站

口碑好的网站开发,浙江坤宇建设有限公司 网站,上海网站开发培训价格,廉政网站 建设需求任务分配问题,有n个任务,每个任务有个达到时间。将这些任务分配给m个处理器,进行处理。每个处理器的处理时间不一样。处理器的任务列表有最大任务数限制。 分配任务的策略是:当前待分配的任务的处理时刻最小。如果处理时刻相同&am…

任务分配问题,有n个任务,每个任务有个达到时间。将这些任务分配给m个处理器,进行处理。每个处理器的处理时间不一样。处理器的任务列表有最大任务数限制。
分配任务的策略是:当前待分配的任务的处理时刻最小。如果处理时刻相同,处理器id小的优先。
假设从时刻0开始分配任务和处理任务。在某一时刻,要求处理器先标记任务的完成状态,再接受新的任务。
问所有问题处理完毕后的时刻是多少?

#include <iostream>
#include <vector>
#include <map>
#include <set>
#include <functional>
#include <string>
#include <queue>
using namespace std;class Solution
{
public:int Dispatch(vector<int> timeUnit, vector<int> arriveTimeList, int queueLen){int n = timeUnit.size();this->timeUnit = timeUnit;this->queueLen = queueLen;taskTime.resize(n, 0);taskCount.resize(n, 0);auto cmp = [&] (int x, int y) -> bool {if (taskCount[x] == queueLen && taskCount[y] == queueLen) {return x > y;}if (taskCount[x] == queueLen) {return true;}if (taskCount[y] == queueLen) {return false;}int time1 = taskTime[x] + timeUnit[x] * taskCount[x];int time2 = taskTime[y] + timeUnit[y] * taskCount[y];if (time1 == time2) {return x > y;}return time1 > time2;};int j = 0;int curTime = 0;for (; ; curTime++) {priority_queue<int, vector<int>, function<bool(int,int)>> q(cmp);// 出队for (int i = 0; i < n; i++) {if (taskCount[i] == 0) {q.push(i);continue;}int cnt = (curTime - taskTime[i]) / timeUnit[i];taskCount[i] -= cnt;if (taskCount[i] < 0) {taskCount[i] = 0;taskTime[i] = 0;} else {taskTime[i] += cnt * timeUnit[i];}q.push(i);}int task = q.top();// 入队,直到不能再加了while (j < arriveTimeList.size() && arriveTimeList[j] <= curTime && taskCount[task] < queueLen) {q.pop();taskCount[task]++;if (taskCount[task] == 1) {taskTime[task] = curTime;}j++;q.push(task);task = q.top();}if (j == arriveTimeList.size()) {break;}}int ans = 0;for (int i = 0; i < n; i++) {ans = max(ans, taskTime[i] + taskCount[i] * timeUnit[i]);}return ans;}
private:vector<int> taskTime;vector<int> taskCount;vector<int> timeUnit;int queueLen;
};int main(int argc, char *argv[])
{vector<int> timeUnit = {1, 2, 3, 4, 5};vector<int> arriveTimeList = {0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 2, 3, 4, 5, 6, 7};int rightAns = 5;Solution s;int ans = s.Dispatch(timeUnit, arriveTimeList, 3);cout << "ans: " << ans << endl;return 0;
}
http://www.yayakq.cn/news/967989/

相关文章:

  • 大馆陶网站网页制作与网站建设实战大全
  • 合肥制作网站价格静安集团网站建设
  • 佛山有哪些建设网站的公司wordpress关闭主题
  • 广西网站建设企业做一家网站要多少钱
  • cetos做网站面料 做网站
  • 东莞网站制作公司阳江网站网站建设
  • 网站建设技能考试试题三揭阳网站制作托管
  • 做网站互联网公司排名客户管理软件单机版
  • 如何文字推广一个婚恋网站asp网站发送邮件
  • 网站用自己的电脑做服务器楚雄建网站
  • 康体设备网站建设关于中秋节网页设计实训报告
  • 潍坊网站制作在线网站建设知名公司
  • 网站建设mus18江苏工信部网站备案
  • 代码家的干货网站电商网站建设企业
  • 网站建设概念股优化推广联盟
  • 网站添加微信支付功能加强网站建设技术培训
  • 南通教育平台网站建设购买wordpress现有模板
  • 网站推广效果怎么样企业管理咨询公司招聘
  • 四川省城乡与建设厅网站首页网页模板下载 免费 html
  • 无锡seo公司seo入门书籍
  • 做珠宝商城网站wordpress导航固定
  • 附近哪里需要招人seo关键词优化报价
  • 涡阳网站建设wordpress theme开发
  • 毕设帮做网站南宁网站建设公司招聘
  • 牡丹江市住房和城乡建设局网站宣传片制作公司费用
  • 合肥网站的优化mysql php网站开发
  • 贵州省住房和城乡建设厅官方网站首页网站开发的实验心德
  • a站下载安装网站制作教程ppt
  • 中小微企业网站建设单位写材料素材网站
  • 建网站申请美团服务商平台