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

滨州内做网站的公司邯郸百度推广公司

滨州内做网站的公司,邯郸百度推广公司,汽油价格网,公司做网络宣传哪个网站比较好1 题目:任务调度器 官方标定难度:中 给你一个用字符数组 tasks 表示的 CPU 需要执行的任务列表,用字母 A 到 Z 表示,以及一个冷却时间 n。每个周期或时间间隔允许完成一项任务。任务可以按任何顺序完成,但有一个限制…

1 题目:任务调度器

官方标定难度:中

给你一个用字符数组 tasks 表示的 CPU 需要执行的任务列表,用字母 A 到 Z 表示,以及一个冷却时间 n。每个周期或时间间隔允许完成一项任务。任务可以按任何顺序完成,但有一个限制:两个 相同种类 的任务之间必须有长度为 n 的冷却时间。

返回完成所有任务所需要的 最短时间间隔 。

示例 1:

输入:tasks = [“A”,“A”,“A”,“B”,“B”,“B”], n = 2
输出:8
解释:
在完成任务 A 之后,你必须等待两个间隔。对任务 B 来说也是一样。在第 3 个间隔,A 和 B 都不能完成,所以你需要待命。在第 4 个间隔,由于已经经过了 2 个间隔,你可以再次执行 A 任务。

示例 2:

输入:tasks = [“A”,“C”,“A”,“B”,“D”,“B”], n = 1

输出:6

解释:一种可能的序列是:A -> B -> C -> D -> A -> B。

由于冷却间隔为 1,你可以在完成另一个任务后重复执行这个任务。

示例 3:

输入:tasks = [“A”,“A”,“A”,“B”,“B”,“B”], n = 3
输出:10
解释:一种可能的序列为:A -> B -> idle -> idle -> A -> B -> idle -> idle -> A -> B。
只有两种任务类型,A 和 B,需要被 3 个间隔分割。这导致重复执行这些任务的间隔当中有两次待命状态。

提示:

1 < = t a s k s . l e n g t h < = 1 0 4 1 <= tasks.length <= 10^4 1<=tasks.length<=104
tasks[i] 是大写英文字母
0 <= n <= 100

2 solution

 贪心算法:数量大的任务优先执行具体做法:把任务放在堆里,取最大值,拿出来过了冷却期在放进去

代码

class Solution {
public:
int leastInterval(vector<char> &tasks, int n) {/** 贪心算法:数量大的任务优先执行* 具体做法:把任务放在堆里,取最大值,拿出来过了冷却*/vector<int> count(26);for (char c: tasks) count[c - 'A']++;int tot = tasks.size();auto lt = [&](const int a, const int b) { return count[a] < count[b];};priority_queue<int, vector<int>, decltype(lt)> pq(lt);for (int i = 0; i < 26; i++) {if (count[i]) pq.push(i);}// while(!pq.empty()){//     int x = pq.top();//     pq.pop();//     cout << char(x + 'A') << " " << count[x] << endl;// }vector<int> startTime(26);queue<int> q;int t = 0;while (tot) {t++;// cout << q.size() << endl;while (!q.empty() && startTime[q.front()] <= t) {pq.push(q.front());q.pop();}// cout << pq.size() << endl;if (pq.empty()) continue;int x = pq.top();pq.pop();// cout << pq.size() << endl;count[x]--;tot--;if(count[x]){q.push(x); // 排队startTime[x] = t + n + 1;}}return t;
}
};

结果

在这里插入图片描述

http://www.dtcms.com/wzjs/240415.html

相关文章:

  • 织梦的网站数据还原怎么做制作网站需要什么技术
  • ps网站CAD做PS地砖贴图网络营销的基本方法
  • 互联网网站基础济南seo网站排名优化工具
  • anker 网站建设网盟推广平台
  • 莱芜金点子招聘网最新招聘福州seo推广服务
  • 经济与政府网站建设建网站需要多少钱
  • 成都网站建设小公司企业互联网推广
  • 交互设计师主要是做什么的呢网络优化工作应该怎么做
  • 番禺网站 建设信科网络什么网站都能打开的浏览器
  • 淘宝网站建设的主要工作河北网站建设制作
  • 广东一站式网站建设推荐推广普通话的宣传内容
  • 做seo时网站发文目的在线seo推广软件
  • PHP网站开发案例12源代码网络推广营销
  • 做赌石网站客服的经验百度搜索排名怎么收费
  • 网站制作合作协议百度品牌广告收费标准
  • 官方网站下载手电筒seo营销外包公司
  • 网站备案 换域名产品网站推广
  • 接做网站需要问什么写文章在哪里发表挣钱
  • 二手服务器做网站今日要闻
  • 赚钱网站平台百度指数网址
  • 美发网站带手机版百度seo公司整站优化
  • 现在新闻做的最好的网站百度广告推广电话
  • 做网站通常用的软件北京推广优化公司
  • 想自己在家做外贸网站商城推广
  • 免费做网站建设站长之家官网
  • 襄樊市网站建设公司seo网站优化方案书
  • 林芝网站建设黄页污水
  • 网站建设征集意见优化资源配置
  • 免费做简历的网站国外免费推广平台有哪些
  • 网站产品页面什么时候做网络营销的八种方式