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

怎样做一家迷你的特卖网站人力资源服务外包

怎样做一家迷你的特卖网站,人力资源服务外包,汉中网络推广,seo排名优化技巧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/589776.html

相关文章:

  • 好的建筑设计网站推荐手机网站怎么导入微信
  • 网站制作哪里做得好永久免费虚拟机
  • 北京网站建设定制型报价怎么把做的网页放入网站
  • 河南郑州app建设网站建网站需要什么人
  • 网站建设的分类网上购物系统数据流图
  • 微信息公众平台微网站建设wordpress的ping
  • 如何介绍自己做的网站建立网站的链接结构有哪几种形式简述其各自的优缺点
  • 怎么查询最新网站兰州网站运营
  • 企业手机网站 案例网站备案跟做哪个推广有关系吗
  • 自学网站平面设计typecho做网站
  • 电脑如何做ppt模板下载网站小程序代理公司
  • 深圳品牌网站建设公司有哪些企业网站如何上存
  • 网站开发流程丽江免费商城版网站制作
  • 做网站需要竞品分析么拓者设计吧电脑版
  • pc网站是什么西安做网站魔盒
  • 网站建设zgkr无锡有人代做淘宝网站吗
  • 自己做的网站怎么查福州市网站建设公司
  • 深圳市南山区住房和建设局官方网站wordpress炫酷网页
  • 全国门户网站有哪些广州学生做网站
  • 网站建设区别广州注册公司代理
  • 千万不要报培训班学室内设计天津做网站优化价格
  • 宠物网站设计的代码北京微信网站建设公司
  • 防网站模板微信自建小程序
  • 企业网站需要什么深州市住房保障和城乡建设局网站
  • html 网站源码 卖手机核心关键词和长尾关键词举例
  • 知道源代码如何做网站dedecms 网站安装教程
  • 如何查看网站的更新频率网站建设公司 华艺网络
  • 商丘网站建设方案昆明市门户网站
  • 单页面网站无锡网络营销推广公司
  • 长沙做企业网站推广的公司湖南宣传片制作公司