华为OD机试 - 最优策略组合下的总的系统消耗资源数(Java 2023 B卷 100分)

news/2024/7/20 17:31:12 标签: 华为od, java, python

在这里插入图片描述

目录

    • 专栏导读
    • 一、题目描述
    • 二、输入描述
    • 三、输出描述
    • 四、解题思路
    • 五、Java算法源码
    • 六、效果展示
      • 1、输入
      • 2、输出
      • 3、说明
      • 4、思路

华为OD机试 2023B卷题库疯狂收录中,刷题点这里

专栏导读

本专栏收录于《华为OD机试(JAVA)真题(A卷+B卷)》。

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

一、题目描述

在通信系统中有一个常见的问题是对用户进行不同策略的调度,会得到不同系统消耗的性能。

假设由N个待串行用户,每个用户可以使用A/B/C三种不同的调度策略,不同的策略会消耗不同的系统资源。

请你根据如下规则进行用户调度,并返回总的消耗资源数。

规则是:相邻的用户不能使用相同的调度策略。

例如:

  1. 第一个用户使用A策略 则第二个用户只能使用B和C策略;
  2. 对单的用户而言,不同的调度策略对系统资源的消耗可以规划后抽象为数值;

例如:

  1. 某用户分别使用ABC策略的系统消耗,分别为15 8 17;
  2. 每个用户依次选择当前所能选择的对系统资源消耗最少的策略,局部最优;
  3. 如果有多个满足要求的策略,选最后一个。

二、输入描述

第一行表示用户个数N。
接下来表示每一行表示一个用户分别使用三个策略的资源消耗,resA resB resC。

三、输出描述

最优策略组合下的总的系统消耗资源数。

四、解题思路

  1. 读取输入的用户数量 n;
  2. 创建一个列表 lists,用于存储每个用户的不同策略和资源消耗;
  3. 循环读取每个用户的资源消耗,将其添加到 lists 中;
  4. 初始化变量 total 表示总的系统消耗资源数,变量 preUser 表示上一个用户所选的策略;
  5. 对每个用户进行调度:
    • 对当前用户的所有策略按照资源消耗从低到高排序,如果资源消耗相同,则将策略索引较大的排在前面,以满足选择最后一个的要求;
    • 遍历排序后的策略,如果是第一个用户,或者当前策略与上一个用户所选的策略不同,选择该策略,并将其资源消耗加到 total 中,更新 preUser 为当前策略索引,然后跳出循环。
  6. 输出 total,即最优策略组合下的总的系统消耗资源数。

五、Java算法源码

java">public static void main(String[] args) {
    Scanner scanner = new Scanner(System.in);
    int n = scanner.nextInt();

    List<List<User>> lists = new ArrayList<List<User>>(n);
    for (int i = 0; i < n; i++) {
        List<User> iUserList = new ArrayList<>(3);
        for (int j = 0; j < 3; j++) {
            User User = new User();
            User.index = j;
            User.value = scanner.nextInt();
            iUserList.add(User);
        }
        lists.add(iUserList);
    }

    int total = 0;
    int preUser = -1;
    for (int i = 0; i < n; i++) {
        // 当前用户的所有策略,按照资源消耗从低到高排序,消耗一样多的,index大的排在前面
        List<User> iUserList = lists.get(i);
        iUserList = iUserList.stream()
                .sorted(Comparator.comparing(User::getIndex)) // 如果有多个满足要求的策略,选最后一个,所以排在前面供选择
                .sorted(Comparator.comparing(User::getValue)) // 后执行的优先级高
                .collect(Collectors.toList());
        for (User User : iUserList) {
            // 第一个用户,或者后面的用户和之前用户不是同一个
            if (preUser == -1 || User.getIndex() != preUser) {
                total += User.getValue();
                preUser = User.getIndex();
                break;
            }
        }
    }
    System.out.println(total);
}

private static class User {
    public int index;
    public int value;

    public int getIndex() {
        return index;
    }

    public void setIndex(int index) {
        this.index = index;
    }

    public int getValue() {
        return value;
    }

    public void setValue(int value) {
        this.value = value;
    }
}

六、效果展示

1、输入

3
15 8 17
12 20 9
11 7 5

2、输出

24

3、说明

1号用户使用B策略
2号用户使用C策略
3号用户使用B策略
系统资源消耗8+9+7。

4、思路

  1. 每个用户可以使用A/B/C三种不同的调度策略,即固定3种;
  2. 每个用户依次选择当前所能选择的对系统资源消耗最少的策略,局部最优,每个用户的策略需要根据资源消耗进行排序;
  3. 相邻的用户不能使用相同的调度策略,即上一个用户选择的这个策略,当前用户就不能再选择;
  4. 如果有多个满足要求的策略,选最后一个。所以还要考虑不同策略消耗资源相等的情况;
  5. 遍历处理每个用户可选择的消耗最小的策略相加;
  6. 可以考虑面向对象编程,代码更易懂;

在这里插入图片描述


🏆下一篇:华为OD机试 - 荒岛求生 - 栈Stack(Java 2023 B卷 100分)

🏆本文收录于,华为OD机试(JAVA)真题(A卷+B卷)

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

在这里插入图片描述


http://www.niftyadmin.cn/n/5076163.html

相关文章

TDengine时序数据库学习使用

数据库要求&#xff1a; 1.目前服务器只能在linux运行&#xff0c;先安装服务器版本v1 2.下载与v1完全匹配的客户端版本v1&#xff08;客户端与服务器的版本号不匹配可能访问不了服务器&#xff09; 第一步 安装 安装服务器注意&#xff0c;安装教程&#xff1a; 使用安装…

Floorplanning with Graph Attention

Floorplanning with Graph Attention DAC ’22 目录 Floorplanning with Graph Attention摘要1.简介2.相关工作3.问题公式化4. FLORA的方法4.1 解决方案概述4.2 C-谱聚类算法 4.3 基于GAT的模型4.4 合成训练数据集生成 摘要 布图规划一直是一个关键的物理设计任务&#xff0…

回文判断的三种写法

谜题&#xff1a;回文 回文是一个单词、数字、短语或其他字符序列&#xff0c;它正反向阅读时都相同。 回文的最简单示例包括madam、racecar、mom、toot、rotor等等... 谜题&#xff1a;回文 这一次&#xff0c;我们将面临在面试中常遇到的一个常见挑战。问题如下&#xff1a; …

[游戏开发][Unity]安卓出包报错记录

打包报错日志有以下几种类型&#xff1a; 报错&#xff1a; CommandInvokationFailure: Android Asset Packaging Tool failed. E:\Android-SDK-Tool\build-tools\33.0.2\aapt.exe package -v -f -F raw.ap_ -A raw -0 "" --ignore-assets "!.svn:!.git:!.ds_st…

arc 166 b

#include<bits/stdc.h> using namespace std; using VI vector<int>; using ll long long; using PII pair <ll , int>; const int mod 998244353; int n; //第 i 个字母 状态为 j 的操作次数 //dp[i][j] dp[i-1][k]ll a[200050]; ll dp[200050][8];//x…

JVM CMS和G1执行过程比较

CMS CMS&#xff08;Concurrent Mark Sweep&#xff09;收集器是一种以获取最短回收停顿时间为目标的收集器。由于大部分 Java 应用主要集中在互联网网站以及基于浏览器的 B/S 系统的服务端&#xff0c;这类应用通常会较为关注服务的响应速度&#xff0c;希望系统的停顿时间尽…

如何实现mac系统远程控制window

Mac和Windows是两个广泛使用的操作系统&#xff0c;它们有着各自的特点和优势。有时候&#xff0c;可能需要在Mac系统上进行工作&#xff0c;但仍然需要远程访问和控制Windows系统。幸运的是&#xff0c;有几种方法可以实现这一目标。 一、远程桌面协议&#xff08;RDP&#xf…

QT位置相关函数

Qt&#xff08;Qt Framework&#xff09;是一个流行的C应用程序开发框架&#xff0c;提供了丰富的位置相关函数和类&#xff0c;用于处理窗口、窗口小部件和图形的位置和几何操作。以下是一些常用的Qt位置相关函数和类&#xff1a; QPoint&#xff1a;QPoint类表示一个二维点的…