【华为OD题库-076】执行时长/GPU算力-Java

题目

为了充分发挥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

思路

以示例1为例,每秒任务执行过程如下:

第1秒开始进来1个任务,执行完成后剩余0个任务(1<=3)

第2秒开始进来2个任务,执行完成后剩余0个任务(2<=3)

第3秒开始进来3个任务,执行完成后剩余0个任务(3<=3)

第4秒开始进来4个任务,执行完成后剩余1个任务(4>3)

第5秒开始进来5+1个任务,执行完成后剩余3个任务(6>3)

第6秒开始进来3个任务,执行完成后剩余0个任务(3>=3)

所以结果为6。

使用curNum记录当前进来的任务数量,使用leaveNum记录当前秒结束后的剩余任务数量。

通过上述过程,可以看到结束的标志是:时间大于等于数组长度并且leaveNum为0。

题解

java 复制代码
package hwod;

import java.util.Scanner;

public class ExecuteTime {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int maxTask = sc.nextInt();
        int n = sc.nextInt();
        int[] nums = new int[n];
        for (int i = 0; i < n; i++) {
            nums[i] = sc.nextInt();
        }
        System.out.println(executeTime(nums, maxTask));
    }

    private static int executeTime(int[] nums, int maxTask) {
        int res = 0;
        int curNum, leaveNum = 0;
        while (res < nums.length || leaveNum != 0) {
            curNum = leaveNum;
            if (res < nums.length) curNum += nums[res];
            leaveNum = curNum > maxTask ? curNum - maxTask : 0;
            res++;
        }
        return res;
    }
}

推荐

如果你对本系列的其他题目感兴趣,可以参考华为OD机试真题及题解(JAVA),查看当前专栏更新的所有题目。

相关推荐
无心水1 天前
【Python实战进阶】7、Python条件与循环实战详解:从基础语法到高级技巧
android·java·python·python列表推导式·python条件语句·python循环语句·python实战案例
一点★1 天前
“equals”与“==”、“hashCode”的区别和使用场景
java·开发语言
N***H4861 天前
SpringCloud实战十三:Gateway之 Spring Cloud Gateway 动态路由
java·spring cloud·gateway
s***w1121 天前
SpringMVC新版本踩坑[已解决]
java
老李头喽1 天前
走进单元测试
java·单元测试
就叫飞六吧1 天前
Spring MVC 接口命名为什么会有 *.do/actions等身影?
java·spring·mvc
葡萄成熟时 !1 天前
黑马学生管理系统
java·开发语言
沐浴露z1 天前
为什么使用SpringAI时通常用Builder来创建对象?详解 【Builder模式】和【直接 new】的区别
java·python·建造者模式
阿杰真不会敲代码1 天前
Filter与Interceptor深度解析:分清这两个“拦截器”,面试不再掉坑
java·spring boot·面试
带刺的坐椅1 天前
Solon AI 开发学习6 - chat - 两种 http 流式输入输出
java·ai·solon