华为OD技术C卷“测试用例执行计划”Java解答
描述

示例


算法思路1
整体思路是,先读取特性的优先级和测试用例覆盖的特性列表,然后计算每个测试用例的优先级,并将其与测试用例的索引存储到二维数组中。最后按照优先级和索引排序,输出测试用例的索引,即为执行顺序。
-
首先从标准输入中读取了两个整数
n和m,分别表示特性的数量和测试用例的数量。 -
创建了一个长度为
n的数组priorities,用于存储特性的优先级。 -
使用循环读取每个特性的优先级,并将其存储到
priorities数组中。 -
通过
in.nextLine()读取了一个空行,用于消耗掉换行符。 -
创建了一个二维数组
res,其行数为测试用例的数量m,列数为2,用于存储测试用例的优先级和对应的索引。 -
使用循环遍历每个测试用例:
- 使用
in.nextLine()读取了一行输入,其中包含了一个测试用例覆盖的特性列表。 - 使用
split(" ")方法将输入拆分为特性的索引数组。 - 使用流式处理将特性的索引转换为整数流,并对每个特性索引计算其对应特性的优先级,并将所有特性的优先级求和。
- 将求和得到的优先级和当前测试用例的索引存储到
res数组中。
- 使用
-
使用
Arrays.sort()对res数组进行排序,排序规则为:- 首先按照测试用例的优先级从大到小排序。
- 如果测试用例的优先级相同,则按照测试用例的索引从小到大排序。
-
使用循环遍历排序后的
res数组,并输出测试用例的索引(ID),注意索引从0开始,需要加1。
答案1
import java.util.Arrays;
import java.util.Scanner;
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);
// 注意 hasNext 和 hasNextLine 的区别int n = in.nextInt();int m = in.nextInt();int[] priorities = new int[n];for (int i = 0; i < n; i++) {priorities[i] = in.nextInt();}in.nextLine();int[][] res = new int[m][2];for (int i = 0; i < m; i++) {int sum = Arrays.stream(in.nextLine().split(" ")).mapToInt(a -> {int idx = Integer.parseInt(a);return priorities[idx - 1];}).sum();res[i][0] = sum;res[i][1] = i;}Arrays.sort(res, (a,b) -> {return b[0]-a[0] == 0 ? a[1] - b[1] : b[0]-a[0];});for (int[] re : res) {System.out.println(re[1]+1);}}
}
详解1
int sum = Arrays.stream(in.nextLine().split(" ")).mapToInt(a -> { int idx = Integer.parseInt(a); return priorities[idx - 1]; }).sum();
in.nextLine()用来读取一行输入。这行输入是一系列用空格分隔的整数,表示任务的优先级索引。
.split(" ")将读取到的一行输入按照空格进行分割,将每个优先级索引分开,形成一个字符串数组。
Arrays.stream()将得到的字符串数组转换为一个流(Stream),这样我们就可以对每个优先级索引进行操作。
.mapToInt(a -> {...})这是一个映射操作,对流中的每个元素进行处理。对于每个优先级索引a,执行一系列操作:a.
int idx = Integer.parseInt(a);将字符串表示的优先级索引转换为整数。b.
priorities[idx - 1]通过索引找到对应的优先级,并返回。
.sum()对映射后的优先级数组求和,得到该任务的总优先级。整体来说,这段代码的作用是将每个任务的优先级索引转换为对应的优先级,然后计算总优先级,最后将这些总优先级存储在
sum变量中。
Arrays.sort(res, (a,b) -> {
return b[0]-a[0] == 0 ? a[1] - b[1] : b[0]-a[0];
});
这段代码使用了一个 lambda 表达式作为比较器,用于比较二维数组
res中的元素。Lambda 表达式的参数是(a, b),其中a和b是res中的每个元素,类型为int[]。Lambda 表达式的主体根据总优先级和任务索引的比较结果返回一个整数值,用于指示元素的相对顺序。Lambda 表达式中的逻辑解释如下:
b[0]-a[0] == 0:首先,按照元素的第一个值(即总优先级)进行比较。如果两个元素的总优先级相等,则进入三元条件运算符的条件部分。
a[1] - b[1]:如果两个元素的总优先级相等,则按照元素的第二个值(即任务索引)进行比较。这部分逻辑会在总优先级相等时生效,以确保相同优先级的任务按照索引升序排列。
b[0]-a[0]:如果两个元素的总优先级不相等,则直接根据总优先级的差值返回比较结果,以便在排序时按照总优先级降序排列。
Lambda表达式应用
Lambda表达式是Java编程语言中引入的一种函数式编程特性。它提供了一种简洁的语法来创建匿名函数,从而更轻松地实现函数式编程风格的代码。Lambda表达式通常用于替代匿名内部类的简单情况,使代码更加简洁和易读。
Lambda表达式的一般语法如下:
(parameters) -> expression或者
(parameters) -> { statements; }Lambda表达式由几个部分组成:
- 参数列表:表示Lambda表达式接受的参数。如果没有参数,可以留空或使用一对空括号
()。- 箭头
->:将参数列表和Lambda表达式的主体分隔开来。- 主体:可以是一个表达式,也可以是一段代码块。如果是一个表达式,它的结果将作为Lambda表达式的返回值。如果是一段代码块,则需要使用大括号
{}将代码块括起来,并且需要使用return关键字来返回值。Lambda表达式的特点包括:
- 简洁性:Lambda表达式使用了一种简洁的语法,可以使代码更加简洁、易读。
- 匿名性:Lambda表达式可以创建匿名函数,无需显式地命名函数。
- 类型推断:Java编译器可以推断Lambda表达式的参数类型,使得Lambda表达式的使用更加方便。
- 语法灵活性:Lambda表达式可以用于函数式接口,使得在需要函数式接口的地方可以使用Lambda表达式代替传统的匿名内部类。
Lambda表达式详见Lambda表达式-CSDN博客
Stream流待更新……
算法思路2
-
读取输入并保存数据结构:
- 读取特性的数量 N 和测试用例的数量 M。
- 创建一个长度为 N 的数组,用于存储特性的优先级。
- 创建一个长度为 M 的列表,其中每个元素是一个集合,表示每个测试用例覆盖的特性。
-
计算测试用例的优先级:
- 遍历测试用例列表,对于每个测试用例,遍历其覆盖的特性集合,累加特性的优先级,得到测试用例的优先级。
-
按照规则排序测试用例:
- 对测试用例列表进行排序,首先按照优先级从大到小排序,如果优先级相同,则按照测试用例的ID从小到大排序。
-
输出测试用例的执行顺序:
- 按照排序后的顺序输出测试用例的ID。
答案2
import java.util.*;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int N = scanner.nextInt(); // 特性的数量int M = scanner.nextInt(); // 测试用例的数量int[] priorities = new int[N + 1]; // 特性的优先级,索引从1开始for (int i = 1; i <= N; i++) {priorities[i] = scanner.nextInt();}scanner.nextLine(); // 消耗换行符List<TestCase> testCases = new ArrayList<>();for (int i = 1; i <= M; i++) {int priority = 0;String[] features = scanner.nextLine().split(" ");for (String feature : features) {int featureId = Integer.parseInt(feature);priority += priorities[featureId];}testCases.add(new TestCase(i, priority));}// 按照优先级从大到小排序,如果优先级相同则按照ID从小到大排序testCases.sort((a, b) -> a.priority != b.priority ? Integer.compare(b.priority, a.priority) : Integer.compare(a.id, b.id));// 输出测试用例的执行顺序for (TestCase testCase : testCases) {System.out.println(testCase.id);}scanner.close();}static class TestCase {int id; // 测试用例的IDint priority; // 测试用例的优先级public TestCase(int id, int priority) {this.id = id;this.priority = priority;}}
}
详解2
list列表接口的使用详见Java“集合框架”知识速成笔记学完就去实战(三)-CSDN博客文章浏览阅读1.1k次,点赞32次,收藏12次。吐血整理!本文为Java中集合类型的一些常见接口和实现类,包括List接口,Set接口和Map接口,重点介绍了HashSet实现类。https://blog.csdn.net/wwwwwmmn/article/details/136433958
相关文章:
华为OD技术C卷“测试用例执行计划”Java解答
描述 示例 算法思路1 整体思路是,先读取特性的优先级和测试用例覆盖的特性列表,然后计算每个测试用例的优先级,并将其与测试用例的索引存储到二维数组中。最后按照优先级和索引排序,输出测试用例的索引,即为执行顺序。…...
solana 入门 1
solana-co-learn Solana 开发学习笔记(一)——从 Hello World 出发 安装开发环境 windows下环境配置 wsl First start with installing WSL on your system. wsl --install wsl安装Ubuntu 列出可用的分发版 wsl.exe --list --online显示: 以下是可安装的有效…...
JavaEE之多线程(创建线程的五种写法)详解
😽博主CSDN主页: 小源_😽 🖋️个人专栏: JavaEE 😀努力追逐大佬们的步伐~ 目录 1. 前言 2. 操作系统"内核" 3. 创建线程的五种写法 (我们重点要掌握最后一种写法!!) 3.1 继承 Thread, 重写 run 3. 2 实现 Runnabl…...
ChatGPT国内能用吗?中国用户怎么才能使用ChatGPT?
与ChatGPT类似的国内网站,他们都能提供和ChatGPT相似的能力,而且可以在国内直接使用。 点击直达方式 百科GPT官网:baikegpt.cn ChatGPT是基于GPT-3.5架构的语言模型的一个实例,由OpenAI开发。以下是ChatGPT的发展历史࿱…...
集群保持集群负载均衡和hash一致性
集群保持负载均衡和一致性哈希是在构建分布式系统时经常涉及的两个重要概念。 负载均衡: - 在集群中,负载均衡是指将传入的请求有效地分发到不同的服务器上,以确保每台服务器都能够处理适量的流量,避免某些服务器过载而造成性能问…...
吴恩达深度学习笔记:神经网络的编程基础2.9-2.14
目录 第一门课:神经网络和深度学习 (Neural Networks and Deep Learning)第二周:神经网络的编程基础 (Basics of Neural Network programming)2.9 逻辑回归中的梯度下降(Logistic Regression Gradient Descent) 第一门课ÿ…...
在C++项目中使用python脚本(四种)常见报错解决
上一期我们讲了如何在C中使用python脚本,这期讲讲过程中常会遇到的一些错误。 一、c代码未设置python路径 Py_SetPythonHome(L"D:\\anaconda3\\envs\\envpython3.7");这一句很重要,切记加上并且换成自己的路径 Py_SetPythonHome(L"D:\\a…...
微前端框架 qiankun 配置使用【基于 vue/react脚手架创建项目 】
qiankun官方文档:qiankun - qiankun 一、创建主应用: 这里以 vue 为主应用,vue版本:2.x // 全局安装vue脚手架 npm install -g vue/clivue create main-app 省略 vue 创建项目过程,若不会可以自行百度查阅教程 …...
nodejs切换淘宝源
1. 查看当前地址 npm config get registrynpm config get disturl2. 设置当前地址(设置为淘宝镜像) npm config set registry http://registry.npm.taobao.org/3. 设置当前地址(设置为默认地址) npm config set registry https…...
怎么避免电脑数据被拷贝?电脑如何禁用USB功能?
在无纸化办公的今天,很多重要数据都存放在电脑中。为了避免数据泄露,需要采用安全的方式保护电脑数据。那么,该如何避免电脑数据被拷贝呢?下面我们就来了解一下。 方法一:物理隔绝 物理隔绝是一种原始但有效的USB禁用…...
给电脑加硬件的办法 先找电脑支持的接口,再买相同接口的
需求:我硬盘太小,换或加一个大硬盘 结论:接口是NVMe PCIe 3.0 x4 1.找到硬盘型号 主硬盘 三星 MZALQ512HALU-000L2 (512 GB / 固态硬盘) 2.上官网查 或用bing查 非官方渠道信息,不确定。...
uniapp微信小程序_自定义交费逻辑编写
一、首先看最终效果 先说下整体逻辑,选中状态为淡紫色,点击哪个金额,充值页面上就显示多少金额 二、代码 <view class"addMoney"><view class"addMoneyTittle">充值金额</view><view class"selfaddmoney" :class"{…...
论文阅读——RingMo
RingMo: A Remote Sensing Foundation Model With Masked Image Modeling 与自然场景相比,RS图像存在以下困难。 1)分辨率和方位范围大:受遥感传感器的影响,图像具有多种空间分辨率。此外,与自然图像的实例通常由于重…...
Hadoop,Hive 数据预处理CR
记录一次大材小用,我在将.csv电影数据集 电影json数据 导入MySQL时,出现了报错: 很明显,意味着.csv中的数据有非utf8编码的, 尝试使用file查看了下.csv文件的编码格式: 如果不确定原始编码,可以先用file命令尝试检测一下: file -i input.csv该命令会显示文件的MIME类型…...
小程序开发——获取设备信息 API(三)
ty.device.getShareDeviceInfo 获取共享设备信息 需引入DeviceKit,且在>2.2.0版本才可使用 请求参数 Object object 属性类型默认值必填说明deviceIdstring是deviceId 设备 idcompletefunction否接口调用结束的回调函数(调用成功、失败都会执行&am…...
Vue2 + node.js项目
1、Vue2 vue2主要功能包括登入、退出、用户权限、表格的增删改查、文件下载。 Vue2项目地址https://gitee.com/www6/finance1.git 2、node.js编写后端接口 2.1、项目初始化 后端地址https://gitee.com/www6/finance-backend.git 创建项目 npm install -g koa-generator …...
如何使用IDE端通义灵码
如何使用IDE端通义灵码 第一步:安装IDE插件( VS Code 和 JetBrains 二选一) 如何下载安装VS Code :https://code.visualstudio.com 如何下载安装JetBrains:https://www.jetbrains.com/idea/download 第二步&#x…...
微服务分布式springcloud的体育场地预约系统演kdm1z
体育场馆设施预约系统是在实际应用和软件工程的开发原理之上,运用java语言以及Springcloud框架进行开发。首先要进行需求分析,分析出体育场馆设施预约系统的主要功能,然后设计了系统结构。整体设计包括系统的功能、系统总体结构、系统数据结构…...
IDEA开启Run Dashboard
1、Run Dashboard是什么,为什么要使用 Run Dashboard 是 IntelliJ IDEA 中的一个工具窗口,用于管理和监视项目中正在运行的应用程序和配置。它提供了一种集中管理运行和调试过程的方式,可以让开发人员更方便地查看和控制正在运行的应用程序。…...
小程序学习3 goods-card
pages/home/home home.wxml <goods-listwr-class"goods-list-container"goodsList"{{goodsList}}"bind:click"goodListClickHandle"bind:addcart"goodListAddCartHandle"/> <goods-list>是一个自定义组件,它具…...
wordpress后台更新后 前端没变化的解决方法
使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…...
Docker 运行 Kafka 带 SASL 认证教程
Docker 运行 Kafka 带 SASL 认证教程 Docker 运行 Kafka 带 SASL 认证教程一、说明二、环境准备三、编写 Docker Compose 和 jaas文件docker-compose.yml代码说明:server_jaas.conf 四、启动服务五、验证服务六、连接kafka服务七、总结 Docker 运行 Kafka 带 SASL 认…...
定时器任务——若依源码分析
分析util包下面的工具类schedule utils: ScheduleUtils 是若依中用于与 Quartz 框架交互的工具类,封装了定时任务的 创建、更新、暂停、删除等核心逻辑。 createScheduleJob createScheduleJob 用于将任务注册到 Quartz,先构建任务的 JobD…...
Qt Http Server模块功能及架构
Qt Http Server 是 Qt 6.0 中引入的一个新模块,它提供了一个轻量级的 HTTP 服务器实现,主要用于构建基于 HTTP 的应用程序和服务。 功能介绍: 主要功能 HTTP服务器功能: 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...
论文浅尝 | 基于判别指令微调生成式大语言模型的知识图谱补全方法(ISWC2024)
笔记整理:刘治强,浙江大学硕士生,研究方向为知识图谱表示学习,大语言模型 论文链接:http://arxiv.org/abs/2407.16127 发表会议:ISWC 2024 1. 动机 传统的知识图谱补全(KGC)模型通过…...
Rust 异步编程
Rust 异步编程 引言 Rust 是一种系统编程语言,以其高性能、安全性以及零成本抽象而著称。在多核处理器成为主流的今天,异步编程成为了一种提高应用性能、优化资源利用的有效手段。本文将深入探讨 Rust 异步编程的核心概念、常用库以及最佳实践。 异步编程基础 什么是异步…...
浅谈不同二分算法的查找情况
二分算法原理比较简单,但是实际的算法模板却有很多,这一切都源于二分查找问题中的复杂情况和二分算法的边界处理,以下是博主对一些二分算法查找的情况分析。 需要说明的是,以下二分算法都是基于有序序列为升序有序的情况…...
使用LangGraph和LangSmith构建多智能体人工智能系统
现在,通过组合几个较小的子智能体来创建一个强大的人工智能智能体正成为一种趋势。但这也带来了一些挑战,比如减少幻觉、管理对话流程、在测试期间留意智能体的工作方式、允许人工介入以及评估其性能。你需要进行大量的反复试验。 在这篇博客〔原作者&a…...
vue3 daterange正则踩坑
<el-form-item label"空置时间" prop"vacantTime"> <el-date-picker v-model"form.vacantTime" type"daterange" start-placeholder"开始日期" end-placeholder"结束日期" clearable :editable"fal…...
嵌入式学习之系统编程(九)OSI模型、TCP/IP模型、UDP协议网络相关编程(6.3)
目录 一、网络编程--OSI模型 二、网络编程--TCP/IP模型 三、网络接口 四、UDP网络相关编程及主要函数 编辑编辑 UDP的特征 socke函数 bind函数 recvfrom函数(接收函数) sendto函数(发送函数) 五、网络编程之 UDP 用…...
