python每日一练

题目一

输入10个整数,输出其中不同的数,即如果一个数出现了多次,只输出一次(要求按照每一个不同的数第一次出现的顺序输出)。

解题

错误题解

python 复制代码
a = list(map(int,input().split()))
b = []
b.append(a[i])
for i in range(2,11):
    if a[i] not in b:
        b.append(a[i])
print(b)

但是会出现i报错,

发散思维一下,要做到遍历a列表里的元素的方法还有,尝试一下

python 复制代码
for element in list1:
python 复制代码
a = list(map(int,input().split()))
b = []
for element in a:
    if element not in b:
        b.append(element)
print(b)

题目二

输入10个学生5门课的考试成绩,分别用函数实现以下功能:

(1)计算一个学生的平均分;(2)计算每门课程的平均分;(3)找出每门课程的最高分。

解题

用字典的典型错误,字典中的key唯一,不允许重复

python 复制代码
a = {}
for i in range(10):
    student_name = input()
    for j in range(5):
        subject = int(input())
        a[student_name] = subject
print(a)

但是发现这样写,相当于每个键对应的值都在最后一次输入中被更新 ,但是想要一个学生的名字对应五个成绩,可以使用列表,一个键对应一个列表。列表的下标就是对应的科目。

python 复制代码
a = {}
for i in range(10):
    student_name = input()
    subject = list(map(int,input().split()))
    a[student_name] = subject
print(a)

现在就完成了输入部分的功能,接下来是输出功能的实现

python 复制代码
a = {}

for i in range(10):
    student_name = input()
    subject = list(map(int, input().split()))
    a[student_name] = subject

student_average = []
for student in a:
    scores = a[student]
    average = sum(scores) / len(scores)
    student_average.append(average)

num_subjects = len(next(iter(a.values())))
subject_totals = [0] * num_subjects
for student in a:
    score_list = a[student]
    for i in range(num_subjects):
        subject_totals[i] += score_list[i]
subject_averages = [total / len(a) for total in subject_totals]
print("\n各科目的平均成绩:")
for i, avg in enumerate(subject_averages, start=1):
    print(f"科目{i}: {avg:.2f}")

# 找出每门课程的最高分
course_max_scores = [float('-inf')] * num_subjects
for student in a:
    score_list = a[student]
    for i in range(num_subjects):
        if score_list[i] > course_max_scores[i]:
            course_max_scores[i] = score_list[i]
print("\n每门课程的最高分:")
for i, max_score in enumerate(course_max_scores, start=1):
    print(f"科目{i}: {max_score}")
    
  
相关推荐
_x_w1 分钟前
【16】数据结构之基于树的排序算法篇章
开发语言·数据结构·python·算法·链表·排序算法
北辰浮光9 分钟前
[SpringMVC]上手案例
java·开发语言
西门吹雪分身15 分钟前
Redis之RedLock算法以及底层原理
数据库·redis·算法
JavaEdge在掘金23 分钟前
告别 Webpack 困惑:一文读懂配置、Loaders 与高效开发流程
python
攻城狮7号30 分钟前
Python爬虫第14节-如何爬取Ajax的数据
爬虫·python·python爬虫
小叶爱吃鱼30 分钟前
python-各种文件(txt,xls,csv,sql,二进制文件)读写操作、文件类型转换、数据分析代码讲解
前端·javascript·python·学习
亿牛云爬虫专家38 分钟前
浏览器自动化检测对抗:修改navigator.webdriver属性的底层实现
python·selenium·自动化·爬虫代理·amazon·代理ip·playwright
一路向北he38 分钟前
杰理10k3950温度测量
java·数据结构·算法
K哥112540 分钟前
【多线程】线程池
java·开发语言·线程池
描绘一抹色1 小时前
力扣-hot100(最长连续序列 - Hash)
数据结构·算法·leetcode