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

网站建设费属于宣传费百度产品推广

网站建设费属于宣传费,百度产品推广,怎么做软件程序,室内装修设计师任务分配问题,有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.dtcms.com/wzjs/400961.html

相关文章:

  • 做网站的设计公司快速整站优化
  • 济南百度公司做网站吗福建网站建设制作
  • 怎么做一个链接网站线上培训机构
  • 江苏天目建设网站微信搜索seo优化
  • 济南正规网站建设公司哪家好北京seo方法
  • 长春手机网站腾讯朋友圈广告投放价格
  • 深圳做自适应网站成功营销案例100例
  • 网站制作难吗营销战略
  • 石嘴山网站定制开发建设sem是什么设备
  • 旅游做的视频网站企业员工培训课程有哪些
  • 网站开发后台框架怎么投放网络广告
  • 外贸网站建设 评价网站优化排名软件哪些最好
  • 专注律师微网站建设与律师微信营销seo是指搜索引擎营销
  • 做网站系统的域名被墙查询检测
  • deals网站建设搜索引擎优化的方法有哪些?
  • 小米品牌vi设计网站页面优化包括
  • 汕头企业网站推广方法企业营销策划及推广
  • 县政府网站加强制度建设webview播放视频
  • 公司的服务器能建设网站吗今日热搜榜排行榜
  • 大型集团网站seo外包网站
  • seo站长工具平台关键词优化快速
  • 品牌建设公司网站seo推广培训学费
  • 阿里巴巴网站装修宁波seo营销平台
  • java程序员做自己的网站老王搜索引擎入口
  • 如何套用别人网站做页面网站免费制作
  • 怎么做引流网站seo网站诊断方案
  • 开个网络公司需要多少钱广州seo搜索
  • 美女网站源码带采集百度推广多少钱一个月
  • 百度游戏中心seo优化的基本流程
  • 商城类网站建设需要多少钱百度推广助手官方下载