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

动易网站做值班表设计一个自己公司网站开发

动易网站做值班表,设计一个自己公司网站开发,面试网站建设工程师,wordpress page id文章目录 前言思路主要思路关于f函数的剖析Code就到这#xff0c;铁子们下期见#xff01;#xff01;#xff01;#xff01; 前言 铁子们好啊#xff01;今天阿辉又给大家来更新新一道好题#xff0c;下面链接是23年9月27的华为笔试原题#xff0c;LeetCode上面的ha… 文章目录 前言思路主要思路关于f函数的剖析Code就到这铁子们下期见 前言 铁子们好啊今天阿辉又给大家来更新新一道好题下面链接是23年9月27的华为笔试原题LeetCode上面的hard难题阿辉带大伙来拿下它 你可以安排的最多任务数目 思路 二分和单调队列以及一丢丢贪心 主要思路 先按照任务难度和工人能力排序 二分的范围是[l,r)左闭右开l 0,r n1最多完成n个任务n取任务数与工人数的较小值因为左闭右开所以r取n1最少完成0个任务所以l取0 然后就是如何判断l与r的中点m是否是能够完成的任务数 排序的重要就在这里体现了我们取任务难度最小的m个与能力最强的m个工人如果能够完成那就能完成如果不能就完成不了 主逻辑代码 // 主函数用于找出可以分配的最大任务数量。int maxTaskAssign(vectorint tasks, vectorint workers, int pills, int strength) {int n min(tasks.size(), workers.size()); // 取任务数和工人数中较小的一个因为任务数不能超过工人数。int l 0; // 二分查找的左边界int r n1; // 二分查找的右边界sort(tasks.begin(), tasks.end()); // 将任务按难度排序sort(workers.begin(), workers.end()); // 将工人按能力排序// 二分查找确定最大可分配任务数while (l r) {int m l (r - l) / 2; // 中间点//f函数用于判断是否可以完成m个任务if (f(tasks, workers, pills, strength, m)) {l m 1; // 如果能完成m个任务则尝试增加任务数} else {r m; // 如果不能完成m个任务则减少任务数}}return l - 1; // 返回最终的任务数因为在二分查找结束时l指向的是第一个不能完成的任务数}关于f函数的剖析 f函数的空间复杂度是 O ( M ) O(M) O(M)因为i和j都只前进不回退也就是只遍历2次m长度的数组 N为任务数组与工人数组的较大值 然后主函数排序两个数组是 O ( N l o g N ) O(NlogN) O(NlogN)二分加上f函数最多也不超过 O ( N l o g N ) O(NlogN) O(NlogN) 所以时间复杂度 O ( N l o g N ) O(NlogN) O(NlogN) 空间复杂度低于 O ( N ) O(N) O(N)队列长度取决于完成任务的数量 int deque[50001]; // 一个双端队列用于存储可能通过使用或不使用药丸完成的任务。// 辅助函数用于判断是否能在当前条件下完成m个任务。bool f(vectorint ts, vectorint ws, int p, int s, int m) {int h 0, t 0; // 双端队列的头部和尾部指针//i指向最容易完成的第一个任务j指向能力第m强的工人//遍历m个最容易完成的任务以及能力最强的m个工人for (int i 0, j ws.size() - m; j ws.size(); j) {// 遍历每一个工人并尝试分配任务while (i m ts[i] ws[j]) {// 如果当前任务可以由工人直接完成则将其加入队列deque[t] ts[i];}//经过上面的if如果队列里面没东西说明该试试药了//如果队列里面有东西可能是前一个工人嗑药留下的if (h t || ws[j] deque[h]) {// 如果队列为空或当前工人无法完成队列头部的任务则尝试使用药丸--p; // 使用一颗药丸while (i m ts[i] ws[j] s) {// 将可以通过使用药丸完成的任务加入队列deque[t] ts[i];}if (h t || p 0 || ws[j] s deque[h]) {// 如果队列依然为空或药丸用完或即使使用药丸也无法完成队列头部的任务则返回falsereturn false;}--t; // 上面没返回说明嗑药有用完成最难的任务一点子贪心各位肯定能懂队列尾部指针前移} else {//否则h; // 工人直接完成了队列头部的任务队列头部指针后移}}//能走到这就说明能完成return true; Code class Solution { public:// 主函数用于找出可以分配的最大任务数量。int maxTaskAssign(vectorint tasks, vectorint workers, int pills, int strength) {int n min(tasks.size(), workers.size()); // 取任务数和工人数中较小的一个因为任务数不能超过工人数。int l 0; // 二分查找的左边界int r n1; // 二分查找的右边界sort(tasks.begin(), tasks.end()); // 将任务按难度排序sort(workers.begin(), workers.end()); // 将工人按能力排序// 二分查找确定最大可分配任务数while (l r) {int m l (r - l) / 2; // 中间点if (f(tasks, workers, pills, strength, m)) {l m 1; // 如果能完成m个任务则尝试增加任务数} else {r m; // 如果不能完成m个任务则减少任务数}}return l - 1; // 返回最终的任务数因为在二分查找结束时l指向的是第一个不能完成的任务数}int deque[50001]; // 一个双端队列用于存储可能通过使用或不使用药丸完成的任务。// 辅助函数用于判断是否能在当前条件下完成m个任务。bool f(vectorint ts, vectorint ws, int p, int s, int m) {int h 0, t 0; // 双端队列的头部和尾部指针for (int i 0, j ws.size() - m; j ws.size(); j) {// 遍历每一个工人并尝试分配任务while (i m ts[i] ws[j]) {// 如果当前任务可以由工人直接完成则将其加入队列deque[t] ts[i];}if (h t || ws[j] deque[h]) {// 如果队列为空或当前工人无法完成队列头部的任务则尝试使用药丸--p; // 使用一颗药丸while (i m ts[i] ws[j] s) {// 将可以通过使用药丸完成的任务加入队列deque[t] ts[i];}if (h t || p 0 || ws[j] s deque[h]) {// 如果队列依然为空或药丸用完或即使使用药丸也无法完成队列头部的任务则返回falsereturn false;}--t; // 完成一个任务队列尾部指针前移} else {h; // 工人直接完成了队列头部的任务队列头部指针后移}}return true; // 如果所有工人都成功分配了任务则返回true} };就到这铁子们下期见
http://www.dnsts.com.cn/news/4382.html

相关文章:

  • 怎么修改网站标题关键词描述永久免费自助建站系统
  • 外包网站开发价格统一门户网站建设参考规范
  • 深圳平湖网站开发网站建设和网站运营包括什么
  • 电信电信网站备案系统网站建设维护课件ppt
  • 临猗商城网站建设平台网页设计技术论文
  • 网站开发要用什么语言网站制作宣传
  • 企业网站源码 可去版权网站网络排名优化方法
  • 专业做网站 台州玉环山东住房和建设厅网站首页
  • 企业网站如何做网警备案长春网站建设q479185700棒
  • 品牌网站制作公司濮阳头条新闻最新消息
  • 公司网站域名如何申请北京网站建设推荐华网天下
  • 东莞哪里能学建设网站兰州画册设计
  • 配送网站开发wordpress网站统计代码放哪个文件
  • 中国糕点网页设计网站批量网站建设合作协议
  • 哪家网络公司做网站沧州网站设计
  • 专业微信网站开发公司wordpress移动移动判断
  • 域名不变 网站改版网站系统繁忙
  • 曲阳路街道网站建设章丘网站建设公司
  • 软件园二期做网站的公司有哪些wordpress数据库分析
  • 网站建设方案有关内容胶州市住房建设局网站
  • 网站备案收费吗wordpress如何做淘宝客
  • 服务专业的建网站公司电话网络营销策划是指
  • 网站空间计算义乌建网站
  • 做任务给钱的网站手机壳图案设计网站
  • 百度入口网站网络营销有哪些主要功能?
  • 网站营销网站营销推广网络广告平台有哪些
  • 保定网站建设公司哪家好浏览器的历史
  • 淘客做网站运营发布网站iis上报404错误
  • 小金县建设局网站用asp.net制作一个网站需要多久
  • 网站制作网页版旺道seo推广系统怎么收费