华为机试 - 高效的任务规划

news2024/11/15 7:33:07

目录

题目描述

输入描述

输出描述

用例

题目解析

算法源码


题目描述

  • 你有 n 台机器,编号为 1~n,每台都需要完成一项工作,机器经过配置后都能完成独立完成一项工作。
  • 假设第 i 台机器你需要花 B 分钟进行设置,然后开始运行,J 分钟后完成任务。
  • 现在,你需要选择布置工作的顺序,使得用最短的时间完成所有工作。
  • 注意,不能同时对两台进行配置,但配置完成的机器们可以同时执行他们各自的工作。

输入描述

  • 第一行输入代表总共有 M 组任务数据(1<M<=10)。
  • 每组数第一行为一个整数指定机器的数量 N(0<N<=1000)。
  • 随后的 N 行每行两个整数,第一个表示 B(0<=B<=10000),第二个表示 J(0<=J<=10000)。
  • 每组数据连续输入,不会用空行分隔。各组任务单独计时。

输出描述

  • 对于每组任务,输出最短完成时间,且每组的结果独占一行。例如,两组任务就应该有两行输出。

用例

输入1
1
2 2
输出4
说明

第一行1:为一组任务,

第二行1:代表只有一台机器,

第三行2 2:表示该机器配置需2分钟,执行需2分钟。

输入2
2
1 1
2 2
3
1 1
2 2
3 3
输出4
7
说明

第一行2:代表两组任务,

第二行2:代表第一组任务有2个机器,

第三行1 1:代表机器1配置需要1分,运行需要1分,

第四行2 2:代表机器2配置需要2分,运行需要2分,

第五行3:代表第二组任务需要3个机器,

第6-8行分别表示3个机器的配置与运行时间。

题目解析

对于JavaScript Node模式来说,本题有两个难点,第一个难点是输入的获取。

如果基于 rl.on('line', line => {}) 事件监听的方式,来获取输入的话,每次事件回调执行完,我们得到的输入数据都将会丢失,因此我们需要将其缓存,但是一旦输入数据被缓存,它和后面的数据就没有了连贯性,比如我们获取到第一行m后,将其缓存在全局变量中,但是下一次获取新的输入时,我们如何知道新输入是什么呢?

在简单输入获取逻辑中,我们可以依赖于输入行数来判断,但是本题在获取完m后,并不能知道还会有多少行输入,因为m只是任务数,而具体多少行输入,还取决于每个任务有几台机器。

因此,我们需要一种类似于,Java语言的Scanner的同步输入获取。

而JavaScript中想将异步操作(事件回调的执行可以看成是异步的)变为同步化执行,那就只能将异步操作封装进Promise,然后利用async,await来阻塞同步代码,达到异步操作同步化执行。

下面代码就是将line事件监听封装进promise对象,只有当有控制台输入时,才会将promise对象的状态更新为fulfilled

function getLine() {
  return new Promise((resolve) => {
    rl.on("line", (line) => {
      resolve(line);
    });
  });
}

因此,我们await 只会在promise对象变为fulfilled时,才会放行程序。

以上就是解决输入获取的方案说明。

下面说明本题算法逻辑:

如上图是两个机器执行的两种方案,我们可以发现

绿色机器先执行的话,总用时最少。

因为,绿色机器的运行时间更长,而橙色机器可以在绿色机器运行过程中完成配置和执行。

因此,我们很容易得出结论:如果想让任务总用时最少,则优先执行运行时间长的机器。这其实就是贪心思维。

之后,就是计算多个机器工作时的最短时间了,

我们可以定义一个数组dp,dp[i]表示0~i台机器完成工作所需的最短时间。

我们假设machine[i] = [config, run],即第i台机器需要配置时间config,运行时间run。

因此 dp[0] = machine[0][0] + machine[0][1]

而 dp[i] = Math.max(dp[i-1], dp[i-1] - machine[i-1][1] + machine[i][0] + machine[i][1]

 如图所示,dp[1] = Math.max(dp[0], dp[0] - machine[0][1] + machine[1][0] + machine[1][1])

绿色标记和图中绿色圈对应,红色标记和图中红色圈对应。

算法源码

/* JavaScript Node ACM模式 控制台输入获取 */
const readline = require("readline");

const rl = readline.createInterface({
  input: process.stdin,
  output: process.stdout,
});

// 将readline获取控制台输入 这种异步操作promisify,后面通过async await,即可实现同步获取控制台输入
function getLine() {
  return new Promise((resolve) => {
    rl.on("line", (line) => {
      resolve(line);
    });
  });
}

async function init() {
  // 同步控制台输入获取
  const m = (await getLine()) - 0; // 获取总任务数m
  const tasks = [];

  // 循环m次,每次获取一个任务下的机器详情
  for (let i = 0; i < m; i++) {
    const n = (await getLine()) - 0; //获取机器数n
    const machines = [];

    //循环n次,每次获取一个机器的 配置时间、运行时间
    for (let j = 0; j < n; j++) {
      const machine = await getLine(); // 获取机器的 配置时间、运行时间
      machines.push(machine.split(" ").map(Number));
    }

    // tasks中存放的是task,每个task下又存放多个机器信息,每个机器信息包括:配置时间、运行时间
    tasks.push(machines);
  }

  // 业务逻辑
  for (let task of tasks) {
    // 将每个任务中的机器工作顺序,按照运行时间降序排序
    task.sort((a, b) => b[1] - a[1]);

    const dp = [];
    // dp[i]表示第i个机器完成工作的最少用时
    dp[0] = task[0][0] + task[0][1];

    // 下面这段逻辑情况题解图示
    for (let i = 1; i < task.length; i++) {
      dp[i] = Math.max(
        dp[i - 1],
        dp[i - 1] - task[i - 1][1] + task[i][0] + task[i][1]
      );
    }

    console.log(dp.at(-1));
  }
}

init();

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/64314.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[附源码]计算机毕业设计室内设计类网站Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Azure考试认证经验

目录 一、概述 1、考试报名 2、考试经验 3、Azure居家考试 4、Azure证书 一、概述 人不管做什么事情&#xff0c;决心很重要。有了目标就要坚定不移的去执行&#xff0c;这是最基本的。如果没有一个正确的心态来学习&#xff0c;建议你放弃。 1、考试报名 Azure考试报名…

2022 年度优秀开源技术

2022 年&#xff0c;我们综合了 OSCHINA 平台上各大认证官方技术团队、开源社区帐号年度发表的内容频率及质量、开展各种活动运营积极性等多方面的表现 具体名单如下&#xff08;按首字母顺序排名&#xff0c;不分先后&#xff09;&#xff1a; Alluxio 官方 …

osgEarth示例分析——osgearth_cluster

前言 osgearth_cluster示例&#xff0c;展示了绘制很多模型时&#xff0c;如何合适设置模型遮挡的混乱情况。 当模型过多时&#xff0c;可以创建 osgEarth::Util::ClusterNode 节点对象&#xff0c;然后创建 osg::NodeList&#xff0c;将需要绘制的节点 node 们&#xff0c;都…

[附源码]计算机毕业设计JAVA影院售票系统

[附源码]计算机毕业设计JAVA影院售票系统 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis M…

Mockito verify Junit5集成 Mockito

Mockito 集成 Junit5 在学习Mockito 如何集成 Junit5 之前&#xff0c;先来学习下 Mockito 基础的verify功能。 Maven依赖 本篇博客代码的Maven依赖如下&#xff0c;源码地址 <dependencies><dependency><groupId>org.springframework</groupId>&l…

分享107个小清新ppt模板,总有一款适合您

PPT下载链接&#xff1a;https://pan.baidu.com/s/1WqaR_29avEgq46iTSLKfmw?pwd5r81 提取码&#xff1a;5r81 源码下载链接&#xff1a;ppt.rar - 蓝奏云 采集的参数 page_count 1 # 每个栏目开始业务content"text/html; charsetgb2312"base_url "https:…

大一学生《Web编程基础》期末网页制作 基于HTML+CSS+JavaScript响应式个人主页相册介绍模板

&#x1f389;精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业…

UNIX环境高级编程_文件IO_文件描述表

这篇文件记录文件描述表。 2 文件描述符表 2.1 什么是文件描述符表 当运行一个程序时&#xff0c;内核会创建进程表task_struct。当open 打开文件后&#xff0c;会在进程表中创建相应的结构体来记录打开的文件&#xff0c;这个结构体就是文件描述符表。 2.2 task_struct 与…

Apple M1 开启HiDPI的新方法,无需虚拟屏,无需SwitchResX

之前折腾2K屏开HiDPI时记录过三种方法&#xff1a; 2020年03月&#xff1a;SwitchResX 开启HiDPI时显示Not installed的解决办法 2020年11月&#xff1a;升级macOS Big Sur 后 HIDPI失效的解决办法 2021年12月&#xff1a; Apple M1 开启HiDPI的新方法&#xff0c;无需关闭SIP&…

MySQL学习笔记(十三)count(*),count(id),count(1),count(字段)区别

count count 是MySQL的一个查询数量统计的函数&#xff0c;我们在平常的工作中经常会用到&#xff0c;count(*),count(id),count(1),count(字段)这4种写法有什么区别呢&#xff1f; //星号 select count(*) from user; //常数 select count(1) from user; //id(主键) select …

片内总线在cpu扮演什么角色?他为什么能实现高效,不同的CPU为什么采用不同的总线协议?

文章目录各种新型片上总线维度&#xff08;Degree&#xff09;跳&#xff08;Hop&#xff09;和跳数&#xff08;Hop Count&#xff0c;HC&#xff09;直连拓扑和路由器Intel的Ring和Mesh总线双Ring结构Mesh Bus结论片上总线&#xff0c;也称作片上网络&#xff08;Network on …

毕业设计-基于机器视觉的火灾烟雾检测识别系统-yolo

目录 前言 课题背景和意义 实现技术思路 实现效果图样例 前言 &#x1f4c5;大四是整个大学期间最忙碌的时光,一边要忙着备考或实习为毕业后面临的就业升学做准备,一边要为毕业设计耗费大量精力。近几年各个学校要求的毕设项目越来越难,有不少课题是研究生级别难度的,对本科…

2023最新SSM计算机毕业设计选题大全(附源码+LW)之java基于网络安全维护的机房设备管理19rya

对于计算机专业的学生最头疼的就是临近毕业时的毕业设计,对于如何选题,技术选型等这些问题,难道了大部分人,确实,还没毕业的学生对于这些问题还比较陌生,只有学习的理论知识,没有实战经验怎么能独自完成毕业设计这一系列的流程,今天我们就聊聊如何快速应对这一难题. 比较容易的…

LSM Tree

LSM Tree 的存储模型&#xff0c;包括 Tidb&#xff0c;HBase等 特点 通过将大量的随机写转换为顺序写&#xff0c;从而极大地提升了数据写入的性能&#xff0c;虽然与此同时牺牲了部分读的性能。 只适合存储 key 值有序且写入大于读取的数据&#xff0c;或者读取操作通常是…

vueX持久化存储插件

场景&#xff1a;我们在做vue项目时&#xff0c;会遇到存储一些公共值&#xff0c;这样方便在不同的页面去调用这些值 vue中有个vuex&#xff0c;一般我们都存储在这里&#xff0c;这样在每个页面都能够调用 但是&#xff0c;当页面刷新了&#xff0c;这些值就被自动清理掉了 这…

第七届 Sky Hackathon 笔记集合贴

Alex_McAvoy--------NVIDIA 7th SkyHackathon&#xff08;二&#xff09;开发套件的安装与测试 Alex_McAvoy--------NVIDIA 7th SkyHackathon&#xff08;三&#xff09;语音数据集的制作 Alex_McAvoy--------NVIDIA 7th SkyHackathon&#xff08;四&#xff09;Nemo ASR 模型训…

vue.js ES6对象字面量的增强写法

1.属性的增强写法 ES5的写法&#xff1a; 运行效果 ES6的写法&#xff1a; 运行效果 2.函数的增强写法 ES5的写法&#xff1a; ES6的写法&#xff1a; 完整代码 <!DOCTYPE html> <html><head><meta charset"utf-8"><meta name"…

基于Javamail的邮件收发系统(系统+论文+开题报告+任务书+外文翻译+文献综述+答辩PPT)

毕业设计&#xff08;论文&#xff09; &#xff08; 20 届&#xff09; 论文&#xff08;设计&#xff09;题目 基于Javamail的邮件收发系统 作 者 二级学院、专业 班 级 指导教师&#xff08;职称&#xff09; 论 文 字 数 论文完成时间 20年月日 基于JavaMail的邮件…

169-Rust和Solana环境配置

之前写过一篇Rust和Solana环境配置的 应该说写得是非常非常好 并不是说博文写得好 而是说写得非常非常的必要 比如我现在就是想要搞Rust和Solana配置 但是好久好久没搞了 已经完全忘记了 看到那一篇博文的时候就感觉想起来了很多 如果可以参考那篇完整做下来的话 就会…