计算机二级-简单应用题

题目要求

编写代码,以实现如下功能:
键盘输入小明学习的课程名称及考分等信息,信息间采用空格分隔,每个课程一行,空行回车结束录入,示例格式如下:
数学 90
语文 95
英语 86
物理 84
生物 87
屏幕输出得分最高的课程及成绩,得分最低的课程及成绩,以及平均分(保留2位小数)。


一、使用列表解决

  • 下面代码可以实现每个 一行,空行回车结束录入
data = input()
while data:
    data = input()

计算机二级-简单应用题_第1张图片

  • 拆分data数据
data = input()
while data:
    ls = data.split()
    print(ls)
    data = input()

计算机二级-简单应用题_第2张图片

  • 将课程和成绩组成列表,加到新的列表中
data = input()
ls = []
while data:
    ls.append(data.split())
    data = input()
    
ls

计算机二级-简单应用题_第3张图片

  • 按成绩从大到小排序
# 因为字符串作比较是一个字符一个字符比的,所有这里要用int将字符串转为数字
# reverse=True 从大到小排列
ls.sort(key=lambda x:int(x[1]),reverse=True)
ls		# [['英语', '100'], ['数学', '90'], ['语文', '80']]
  • 计算所有科目成绩的和
n = 0
for i in range(len(ls)):
    # ls[i][1] 是 字符串,不能运算
    n += int(ls[i][1])
    
n	# 270
# 平均分
avg = n/len(ls)	# 90.0
print("最高分课程是{} {}, 最低分课程是{} {}, 平均分是{:.2f}".format(ls[0][0],ls[0][1],ls[-1][0],ls[-1][1],avg))
# 最高分课程是英语 100, 最低分课程是语文 80, 平均分是90.00
  • 完整代码
data = input()
ls = []
while data:
    ls.append(data.split())
    data = input()
ls.sort(key=lambda x:int(x[1]),reverse=True)
n = 0
for i in range(len(ls)):
    n += int(ls[i][1])
avg = n/len(ls)
print("最高分课程是{} {}, 最低分课程是{} {}, 平均分是{:.2f}".format(ls[0][0],ls[0][1],ls[-1][0],ls[-1][1],avg))

输入

语文 80
数学 90
英语 100

输出

最高分课程是英语 100, 最低分课程是语文 80, 平均分是90.00

二、使用字典解决

data = input()
d = {}
while data:
    t = data.split()
    # 将列表t
    d[t[0]] = t[1]
    data = input()
    
d

计算机二级-简单应用题_第4张图片

  • 字典的键值
d.items()
# dict_items([('语文', '77'), ('数学', '88'), ('英语', '99')])
d.keys()
# dict_keys(['语文', '数学', '英语'])
d.values()
# dict_values(['77', '88', '99'])


for k,v in d.items():
    print(k,v)
# 语文 77
# 数学 88
# 英语 99
for i in d.keys():
    print(i)
# 语文
# 数学
# 英语
  • 字典转换为列表
# 默认将字典的键转为列表
list(d)
# ['语文', '数学', '英语']

list(d.items())
# [('语文', '77'), ('数学', '88'), ('英语', '99')]
ls = list(d.items())
  • 列表排序
# sort() 按照键的拼音字母比较
ls.sort()
ls
# [('数学', '88'), ('英语', '99'), ('语文', '77')]

# sort() 默认从小到大排序(reverse=False)
ls.sort(key=lambda x:x[1])
ls
# [('语文', '77'), ('数学', '88'), ('英语', '99')]

ls.sort(key=lambda x:x[1],reverse=True)
ls
# [('英语', '99'), ('数学', '88'), ('语文', '77')]
  • 计算总分
zongfen = 0
for i in d.values():
    # 字典的值是字符串,转变为int后计算
    zongfen += int(i)
  • 完整代码
data = input()
d = {}
while data:
    t = data.split()
    d[t[0]] = t[1]
    data = input()

ls = list(d.items())
ls.sort(key=lambda x:x[1],reverse=True)

zongfen = 0
for i in d.values():
    zongfen += int(i)
    
avg = zongfen/len(ls)
print("最高分课程是{} {}, 最低分课程是{} {}, 平均分是{:.2f}".format(ls[0][0],ls[0][1],ls[-1][0],ls[-1][1],avg))

输入

语文 77
数学 88
英语 99

输出

最高分课程是英语 99, 最低分课程是语文 77, 平均分是88.00

你可能感兴趣的:(python,计算机二级,jupyter)