华为OD机试 Java 实现【最优策略组合下的总的系统消耗资源数】【牛客练习题】,附详细解题思路

一、题目描述

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

假设由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. 对每个用户进行调度:
    • 对当前用户的所有策略按照资源消耗从低

你可能感兴趣的:(java,算法,华为机试)