Problem Description
陈是电子元件实验室的一名负责老师,学校最近采购了一批电阻器,他需要做的工作就是给这些电阻器分好类,并且计算好每种电阻器的数量,并按照大小顺序给他们排好序,存放在实验室中。
已知电阻器总共有四类:
薄膜电阻器 film resistor (FILM)
绕线式电阻器 wire resistors (WIRE)
实心电阻器 solid resistor (SOLI)
敏感电阻器 sensitive resistors (SENS)
每一类电阻器对应的各种型号,比如说wire_resistors01代表通用线绕电阻器,它属于线绕式电阻器,为了简单起见,所给的元件中前四个字母代表了它对应的电阻器的类别,即前四个字母为”film”代表薄膜电阻器FILM,前四个字母为“wire”代表线绕式电阻器WIRE,前四个字母为”soli”代表实心电阻器SOLI,前四个字母为”sens”代表敏感电阻器SENS。
Input Description
每个测试样例第一行为一个正整数n(n<=50)表示有n种类型的电阻器。当n为0时,测试结束。
接下来有n行,每行有一个字符串s(长度小于15)和一个整数k(k<=20)。其中s代表电阻器的型号,n代表该型号电阻器的数量。
Output Description
每一个样例对应的输出为四行,其中每行对应一个类别的电阻器,且按照它们数量的大小从小到大输出。测试数据保证不会出现两类电阻器数量相同的情况。
每行的内容为一个字符串t和一个整数sum,其中t只可能是”FILM”,”WIRE”,”SOLI”,”SENS”中的一种。sum代表该类别电阻阻器的总数量。
Sample Input
5
wire_resistors0a 10
solid_resistors0b 8
solid_resistors0c 7
sensitive_resistors0d 16
wire_resistors0e 10
0
Sample Output
FILM 0
SOLI 15
SENS 16
WIRE 20
Hint
我的想法:
我的代码:
if __name__ == '__main__':
ex_list = ["FILM",
"SOLI",
"SENS",
"WIRE"]
while True:
n = int(input())
if n == 0:
break
# 数据列表
list_data = [0, 0, 0, 0]
for i in range(0, n):
line = input().split(" ")
# 截取前四个元素做比较
# 将其全部转为大写
u = line[0][0:4].upper()
index = ex_list.index(u)
list_data[index] = list_data[index] + int(line[1])
out = []
for item1, item2 in zip(ex_list, list_data):
out.append([item1, item2])
# 排序
out_ = sorted(out, key=lambda o:o[1], reverse=False)
for it in out_:
print(f"{it[0]} {it[1]}")