用python实现学车费用的具体代码,题目要求如下:排序规则: 先按总费用从多到少排序,若总费用相同则按姓名的ASCII码序从小到大排序,若总费用相同而且姓名也相同则按编号(即输入时的顺序号,从1开始编)从小到大排序。输入格式: 测试数据有多组,处理到文件尾。每组测试数据先输入一个正整数n(n≤20),然后是n行输入,第i行先输入第i个人的姓名(长度不超过10个字符,且只包含大小写英文字母),然后再输入若干个整数(不超过10个),表示第i个人的各项费用,数据之间都以一个空格分隔,第i行输入的编号为i。输入数据和结果均在32位int型范围之内。 输出格式: 对于每组测试,在按描述中要求的排序规则进行排序后,按顺序逐行输出每个人费用情况,包括:费用排名(从1开始,费用相同则排名也相同)、编号、姓名、总费用。每行输出的数据之间留1个空格。特别说明:如果姓名相同排序为同一等级,钱数相同视为同等级别。以下为输出输出样例:输入样例: 3 Tom 2800 900 2000 500 600 Jack 3800 400 1500 300 Tom 6700 100 3 Tom 2800 400 100 Jack 3800 800 mary 3300。 输出样例: 1 1 Tom 6800 1 3 Tom 6800 3 2 Jack 6000 1 2 Jack 4600 2 1 Tom 3300 2 3 mary 3300 我想要达到的结果python关于不定程度数组的输入
时间: 2023-06-12 22:04:24 浏览: 169
以下是一个实现该题目要求的Python代码,其中使用了字典和元组来存储每个人的信息,并使用sorted函数进行排序:
```python
while True:
try:
n = int(input())
data = {}
for i in range(1, n+1):
line = input().split()
name = line[0]
fee = sum(map(int, line[1:]))
data[i] = (name, fee)
sorted_data = sorted(data.items(), key=lambda x: (-x[1][1], ord(x[1][0][0]), x[0]))
for i, (num, (name, fee)) in enumerate(sorted_data):
rank = i+1
print(f"{rank} {num} {name} {fee}")
except:
break
```
输入数据的格式为:第一行为一个正整数n,表示有n个人;接下来的n行每行表示一个人的信息,包括姓名和各项费用,数据之间用空格分隔。每个人的编号即为输入时的顺序号,从1开始编。
输出数据的格式为:每行表示一个人的费用情况,包括费用排名、编号、姓名和总费用,数据之间用空格分隔。其中费用排名从1开始,如果有多个人费用相同,则排名相同。如果姓名相同,则按ASCII码序从小到大排序。如果总费用相同而且姓名也相同,则按编号从小到大排序。
阅读全文