欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 会展 > 【2024最新华为OD-C/D卷试题汇总】[支持在线评测] LYA的测试用例执行计划(100分) - 三语言AC题解(Python/Java/Cpp)

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] LYA的测试用例执行计划(100分) - 三语言AC题解(Python/Java/Cpp)

2025/7/6 7:57:46 来源:https://blog.csdn.net/Qmtdearu/article/details/139827671  浏览:    关键词:【2024最新华为OD-C/D卷试题汇总】[支持在线评测] LYA的测试用例执行计划(100分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员

✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解

💻 ACM银牌🥈| 多次AK大厂笔试 | 编程一对一辅导

👏 感谢大家的订阅➕ 和 喜欢💗

📎在线评测链接

https://app5938.acapp.acwing.com.cn/contest/2/problem/OD1069
🌍 评测功能需要 ⇒ 订阅专栏 ⇐ 后私信联系清隆解锁~

🍓OJ题目截图

在这里插入图片描述

文章目录

    • 📎在线评测链接
    • 🍓OJ题目截图
    • 🎀 LYA的测试用例执行计划
    • 问题描述
    • 输入格式
    • 输出格式
    • 样例输入
    • 样例输出
    • 样例解释
    • 样例输入
    • 样例输出
    • 样例解释
    • 数据范围
    • 题解
    • 参考代码

🎀 LYA的测试用例执行计划

问题描述

LYA是一名软件测试工程师,她需要为当前迭代周期内的 N N N 个特性 ( F 1 , F 2 , … , F N ) (F_1,F_2,\ldots,F_N) (F1,F2,,FN) 设计测试用例。每个特性都有一个优先级,特性用它的编号 i i i 来表示。

LYA设计了 M M M 个测试用例 ( T 1 , T 2 , … , T M ) (T_1,T_2,\ldots,T_M) (T1,T2,,TM),每个测试用例覆盖了一些特性。测试用例的优先级定义为它所覆盖的所有特性的优先级之和。

在开始测试之前,LYA需要安排这 M M M 个测试用例的执行顺序。她希望优先级高的测试用例先执行。如果两个测试用例的优先级相同,那么编号较小的测试用例先执行。

请你帮助LYA生成这个测试用例的执行计划。

输入格式

第一行包含两个正整数 N N N M M M,分别表示特性的数量和测试用例的数量。

接下来 N N N 行,每行一个整数,第 i i i 行的整数表示特性 F i F_i Fi 的优先级。

再接下来 M M M 行,每行若干个整数,表示一个测试用例覆盖的特性的编号。

  • 1 ≤ N , M ≤ 100 1 \le N,M \le 100 1N,M100
  • 每个特性的优先级是不超过 1 0 9 10^9 109 的正整数
  • 每个测试用例覆盖的特性编号互不相同

输出格式

输出 M M M 行,每行一个整数,表示测试用例的执行顺序。

样例输入

5 4
1
1
2
3
5
1 2 3
1 4
3 4 5
2 3 4

样例输出

3
4
1
2

样例解释

测试用例的优先级计算如下:

  • T 1 T_1 T1 覆盖特性 F 1 , F 2 , F 3 F_1,F_2,F_3 F1,F2,F3,优先级为 1 + 1 + 2 = 4 1+1+2=4 1+1+2=4
  • T 2 T_2 T2 覆盖特性 F 1 , F 4 F_1,F_4 F1,F4,优先级为 1 + 3 = 4 1+3=4 1+3=4
  • T 3 T_3 T3 覆盖特性 F 3 , F 4 , F 5 F_3,F_4,F_5 F3,F4,F5,优先级为 2 + 3 + 5 = 10 2+3+5=10 2+3+5=10
  • T 4 T_4 T4 覆盖特性 F 2 , F 3 , F 4 F_2,F_3,F_4 F2,F3,F4,优先级为 1 + 2 + 3 = 6 1+2+3=6 1+2+3=6

按照优先级从高到低,优先级相同时按编号从小到大的顺序,测试用例的执行顺序应该是 T 3 , T 4 , T 1 , T 2 T_3,T_4,T_1,T_2 T3,T4,T1,T2

样例输入

3 3
3
1
5
1 2 3
1 2 3
1 2 3

样例输出

1
2
3

样例解释

三个测试用例的优先级都是 3 + 1 + 5 = 9 3+1+5=9 3+1+5=9,所以按照编号从小到大的顺序执行。

数据范围

  • 1 ≤ N , M ≤ 100 1 \le N,M \le 100 1N,M100
  • 1 ≤ 1 \le 1 每个特性的优先级 ≤ 1 0 9 \le 10^9 109

题解

本题可以用排序来解决。

首先,我们可以计算出每个测试用例的优先级。具体做法是,遍历每个测试用例覆盖的特性,将这些特性的优先级累加起来,就得到了这个测试用例的优先级。

然后,我们可以将测试用例按照优先级从高到低排序。如果两个测试用例的优先级相同,就按照编号从小到大排序。

最后,我们按照排序后的顺序,依次输出每个测试用例的编号,就得到了最终的执行计划。

时间复杂度分析:计算每个测试用例的优先级需要 O ( N M ) O(NM) O(NM) 的时间,排序需要 O ( M log ⁡ M ) O(M \log M) O(MlogM) 的时间,输出结果需要 O ( M ) O(M) O(M) 的时间。因此,总时间复杂度是 O ( N M + M log ⁡ M ) O(NM + M \log M) O(NM+MlogM)

参考代码

  • Python
n, m = map(int, input().split())
priority = [int(input()) for _ in range(n)]test_cases = []
for i in range(m):features = list(map(int, input().split()))p = sum(priority[f - 1] for f in features)test_cases.append((p, i + 1))test_cases.sort(key=lambda x: (-x[0], x[1]))for _, id in test_cases:print(id)
  • Java
import java.util.*;public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);int n = in.nextInt();int m = in.nextInt();int[] priority = new int[n];for (int i = 0; i < n; i++) {priority[i] = in.nextInt();}List<TestCase> testCases = new ArrayList<>();in.nextLine(); // consume the remaining newlinefor (int i = 0; i < m; i++) {String line = in.nextLine();String[] features = line.split(" ");int p = 0;for (String feature : features) {p += priority[Integer.parseInt(feature) - 1];}testCases.add(new TestCase(p, i + 1));}testCases.sort((a, b) -> {if (a.priority != b.priority) {return b.priority - a.priority;}return a.id - b.id;});for (TestCase testCase : testCases) {System.out.println(testCase.id);}}static class TestCase {int priority;int id;TestCase(int priority, int id) {this.priority = priority;this.id = id;}}
}
  • Cpp
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;int main() {int n, m;cin >> n >> m;vector<int> priority(n);for (int i = 0; i < n; i++) {cin >> priority[i];}vector<pair<int, int>> testCases;for (int i = 0; i < m; i++) {int feature;int p = 0;while (cin >> feature) {p += priority[feature - 1];if (cin.get() == '\n') {break;}}testCases.emplace_back(p, i + 1);}sort(testCases.begin(), testCases.end(), [](const auto& a, const auto& b) {if (a.first != b.first) {return a.first > b.first;}return a.second < b.second;});for (const auto& testCase : testCases) {cout << testCase.second << endl;}return 0;
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词