算法题--华为od机试考试(执行时长、找数字、数据最节约的备份方法)

2024-05-25 12:12

本文主要是介绍算法题--华为od机试考试(执行时长、找数字、数据最节约的备份方法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

执行时长

题目描述

输入描述

输出描述

示例1

输入

输出

说明

示例2

输入

输出

说明

解析

找数字

题目描述

输入描述

输出描述

示例1

输入

输出

示例2

输入

输出

示例3

输入

输出

解析

数据最节约的备份方法

题目描述

输入描述

输出描述

备注

示例1

输入

输出

示例2

输入

输出

解析


执行时长

考察理解能力

题目描述

为了充分发挥GPU算力,需要尽可能多的将任务交给GPU执行,现在有一个任务数组,数组元素表示在这1秒内新增的任务个数且每秒都有新增任务,

假设GPU最多一次执行n个任务,一次执行耗时1秒,在保证GPU不空闲情况下,最少需要多长时间执行完成

输入描述

第一个参数为GPU一次最多执行的任务个数,取值范围[1,10000]

第二个参数为任务数组长度,取值范围[1,10000]

第三个参数为任务数组,数字范围[1,10000]

输出描述

执行完所有任务最少要要多少秒

示例1

输入

3

5

1 2 3 4 5

输出

6

说明

 一次最多执行3个任务,最少耗时6s。

示例2

输入

4

5

5 4 1 1 1

输出

5

说明

一次最多执行4个任务,最少耗时5s

解析

按顺序执行,每次用最多执行的任务个数减去当前的任务个数和上次剩余的个数,如果有剩余的任务未执行就留到下一次,

如果没有则下一次剩余的任务为0,最后剩下的任务直接除以最多执行的任务个数向上取整。

function executeTime(n, len, arr) {let tmp = 0for (let i = 0; i < len; i++) {if (n > arr[i]) {tmp = (tmp - n + arr[i]) < 0 ? 0 : (tmp - n + arr[i])} else {tmp = tmp + arr[i] - n}}return len + Math.ceil(tmp / n)}console.log(executeTime(3, 5, [1, 2, 3, 4, 5]))console.log(executeTime(4, 5, [5, 4, 1, 1, 1]))

找数字

考察二进制和十进制的转换

题目描述

小扇和小船今天又玩起来了数字游戏,

小船给小扇一个正整数 n(1 ≤ n ≤ 1e9),小扇需要找到一个比 n 大的数字 m,使得 m 和 n 对应的二进制中 1 的个数要相同,如:

4对应二进制100

8对应二进制1000

其中1的个数都为1个

现在求 m 的最小值。

输入描述

输入一个正整数 n(1 ≤ n ≤ 1e9)

输出描述

输出一个正整数 m

示例1

输入

128

输出

256

示例2

输入

6

输出

9

示例3

输入

5

输出

6

解析

将n转换为二进制,如果是所有的1在左边,0在右边,则需要进一位,例如111100 => 1000111。全为1也同样需要进一位。

其它情况从右到左,把第一个01交换顺序即可,例如1001 => 1010。最后将结果转为十进制的数字。

function getMin(n) {let arr = n.toString(2).split('').map(Number)for (let i = arr.length - 2; i > 0; i--) {if (arr[i] === 0 && arr[i + 1] === 1) {arr[i + 1] = 0arr[i] = 1return parseInt(arr.join(''), 2)}}arr = arr.sort((a, b) => a - b)arr[arr.indexOf(1)] = 0arr.unshift(1)return parseInt(arr.join(''), 2)
}
console.log(getMin(128))
console.log(getMin(6))
console.log(getMin(5))

数据最节约的备份方法

考察二分法、深度遍历、递归

题目描述

有若干个文件,使用刻录光盘的方式进行备份,假设每张光盘的容量是500MB,求使用光盘最小的

文件分布方式所有文件的大小都是整数的MB,且不超过500MB;文件不能分隔、分卷打包

输入描述

组文件大小的数据

输出描述

使用光盘的数量

备注

不用考虑输入数据不合法的情况;假设最多100个输入文件

示例1

输入

100,500,300,200,400

输出

3

示例2

输入

1,100,200,300

输出

2

解析

这里我们采用二分法确定最小使用光盘的数量。例如示例1有5组文件,这里我们先确认3个光盘是否可以装下,用深度遍历去分析,如果可以的话,再确认(1+3)/2=2个光盘

是否可以装下,不行的话,返回最小为3,可以的话继续上述操作。

这里关键在于dfs函数函数实现:

1.确定入参,1>当前所有光盘容量、2>组文件、3>当前需要装的序号。这里2、3是用来表示剩余的未装光盘数据,可以用一个数组表示,不过需要一直改变数组的长度大小。

2.确定f(x)和f(x-1)的关系。f(x)=f(x-1)0 || f(x-1)1 || ...。

当前这一次等于将x的数据依次放入所有光盘中取或,f(x-1)0表示把x的数据放入0号光盘中,只有有一组可以返回true即表示当前的光盘数量可以装下所有数据。

3.确定出口和剪枝,

    1>光盘容量+当前需要放下的数据小于等于500才能放入

    2>当放入的序号等于组文件数量是表示已全部放入,返回true

    3>当前的光盘和上一个光盘容量大小一样,故装入该光盘中和装入上一个光盘中无区别,可以跳过

    4>下一次循环前需还原光盘容量

function minCopy(str) {let arr = str.split(',').map(Number).sort((a, b) => b - a)let l = 1;let r = arr.length;let ans = r;// 二分模板while (l <= r) {const mid = Math.floor((l + r) / 2);if (check(mid, arr)) {ans = mid;r = mid - 1;} else {l = mid + 1;}}return ans;
}
// 返回bucket.length个光盘是否可以装下,bucket为光盘,num为未装的组文件,index为当前需要装的组文件序号
function dfs(buckets, nums, index) {// 所有组文件都已装入光盘中if (index === nums.length) {return true;}// 将序号为index的组文件依次递归放入bucket中for (let i = 0; i < buckets.length; i++) {// 剪枝,当前的光盘和上一个光盘容量大小一样,故装入该光盘中和装入上一个光盘中无区别,可以跳过if (i !== 0 && buckets[i] === buckets[i - 1]) {continue;}// 该光盘可以装下此组文件if (buckets[i] + nums[index] <= 500) {buckets[i] += nums[index]; //回溯// 找到结果后不再往下递归if (dfs(buckets, nums, index + 1)) {return true;}// 下一次循环前还原光盘容量buckets[i] -= nums[index];}}return false;
}// 返回是否能使用count个光盘备份数据
function check(count, nums) {const buckets = new Array(count).fill(0);return dfs(buckets, nums, 0);}
console.log(minCopy('100,500,300,200,400'))
console.log(minCopy('1,100,200,300'))

这篇关于算法题--华为od机试考试(执行时长、找数字、数据最节约的备份方法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1001466

相关文章

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

Java Thread中join方法使用举例详解

《JavaThread中join方法使用举例详解》JavaThread中join()方法主要是让调用改方法的thread完成run方法里面的东西后,在执行join()方法后面的代码,这篇文章主要介绍... 目录前言1.join()方法的定义和作用2.join()方法的三个重载版本3.join()方法的工作原

Spring Bean初始化及@PostConstruc执行顺序示例详解

《SpringBean初始化及@PostConstruc执行顺序示例详解》本文给大家介绍SpringBean初始化及@PostConstruc执行顺序,本文通过实例代码给大家介绍的非常详细,对大家的... 目录1. Bean初始化执行顺序2. 成员变量初始化顺序2.1 普通Java类(非Spring环境)(

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +