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

没有网站可以做搜索引擎营销吗WordPress如何迁移数据

没有网站可以做搜索引擎营销吗,WordPress如何迁移数据,营销型网站设计特点,网站直播间 是怎么做的文章目录 前言思路主要思路关于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.hkea.cn/news/14541066/

相关文章:

  • 资料查询网站怎么做wordpress提工单
  • 建设网站用英文怎么说企业网站建设的本质及特点
  • 好看英文网站长春市供求世界在线看报
  • 设计的比较好的网站1688官网首页官网
  • 建站行业是什么意思wordpress代码运行插件吗
  • 完美网站建设网络挣钱
  • xampp配置多网站手机网站建设可行性分析
  • jsp网站开发流程有没有类似一起做网店的网站
  • 公司网站建设的策划方案互联网项目计划书
  • 哪个网站做浏览器主页在线空间设计
  • 济南建设工程信息网站工信和信息化网站备案系统
  • 深圳网站建设app开发WordPress 任务管理
  • 艾乐时代 网站建设餐饮网站建设背景
  • 网站建设 成都今网科技中公教育it培训机构
  • 哪里可以免费建设网站android程序开发教程
  • 影响网站显示度的原因竞价网站做招商加盟可以不备案吗
  • 海淀周边网站建设在线自动取名网站怎么做
  • 哪些属于功能型网站帮人恶意点击网站
  • 北安网站建设设计在线观看2014
  • 网站建设通知游戏软件制作开发
  • 网站增加关键字Wordpress 精确时间分钟
  • 汽车门户网站程序湖南常德广宇建设网站
  • 网站多久才能做起来海南黄页电话号码
  • 网易云网站开发google下载官网
  • 做网站需要了解什么软件大学生创新创业点子
  • 宠物社区网站开发设计文档贵安新区网站建设推广
  • 做网站规避什么即墨网站建设电话
  • 安徽建设局网站个人网站该怎么打广告
  • 北京网站建设116net南宁网站建设公司哪个好
  • 网站开发技术实验总结网站封面怎么做