2024. 1华为od机试C卷【测试用例执行计划】Python

题目

某个产品当前迭代周期内有 N 个特性(F1.F2...FN)需要进行覆盖测试,每个特性都被评估了对应的优先级,特性使用其 ID 作为下标进行标识。
设计了 M 个测试用例(T1,T2...TM),每个测试用例对应一个看盖特性的集合,测试用例使用其 ID 作为下标进行标识,测试用例的优先级定义为其覆盖的特性的优先级之和。
在开展测试之前,需要制定测试用例的执行顺序,规则为:优先级大的用例先执行,如果存在优先级相同的用例,用例 ID 小的先执行


输入描述
第一行输入为N和 M,
N 表示特性的数量,0< N <= 100
M 表示测试用例的数量,0 < M <= 100
之后 N 行表示特性 ID=1 到特性 ID=N 的优先级
再接下来 M 行表示测试用例 ID=1 到测试用例ID=M 关联的特性的 ID 的列表

输出描述
按照执行顺序(优先级从大到小) 输出测试用例的 ID,每行一个ID测试用例覆盖的 ID 不重复。

示例1:

输入:

5 4
1
1
2
3
5
1 2 3
1 4
3 4 5
2 3 4
输出:

3
4
1
2
说明
测试用例的优先级计算如下:
T1 = Pf1 + Pf2 + Pf3 = 1 + 1 + 2 = 4
T2 = Pf1 + Pf4 = 1 + 3 = 4
T3 = Pf3 + Pf4 + Pf5 = 2 + 3 + 5 = 10
T4 = Pf2 + Pf3 + Pf4 = 1 + 2 + 3 = 6
按照优先级从小到大,以及相同优先级,ID小的先执行的规则,执行顺序为T3,T4,T1,T2

示例2:

输入:

3 3
3
1
5
1 2 3
1 2 3
1 2 3
输出:

1
2
3
说明
测试用例的优先级计算如下:
T1 = Pf1 + Pf2 + Pf3 = 3 + 1 + 5 = 9
T2 = Pf1 + Pf2 + Pf3 = 3 + 1 + 5 = 9
T3 = Pf1 + Pf2 + Pf3 = 3 + 1 + 5 = 9
每个优先级一样,按照 ID 从小到大执行,执行顺序为T1,T2,T3

代码

[n, m] = list(map(int, input().split(' ')))
special = [0]
test_case = []
for i in range(n):
    special.append(int(input()))

for j in range(m):
    sum_s = 0
    temp = list(map(int, input().split(' ')))
    for k in range(len(temp)):
        sum_s += special[temp[k]]
    test_case.append([j + 1, sum_s])

test_case.sort(key=lambda x: (-x[1], x[0]))
for i in range(m):
    print(test_case[i][0])

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值