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}")
    
  
相关推荐
孟健1 小时前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
HXhlx2 小时前
CART决策树基本原理
算法·机器学习
码路飞3 小时前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
Wect3 小时前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱3 小时前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
曲幽5 小时前
FastAPI压力测试实战:Locust模拟真实用户并发及优化建议
python·fastapi·web·locust·asyncio·test·uvicorn·workers
敏编程10 小时前
一天一个Python库:jsonschema - JSON 数据验证利器
python
前端付豪10 小时前
LangChain记忆:通过Memory记住上次的对话细节
人工智能·python·langchain
databook10 小时前
ManimCE v0.20.1 发布:LaTeX 渲染修复与动画稳定性提升
python·动效
Gorway10 小时前
解析残差网络 (ResNet)
算法