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}")
    
  
相关推荐
2501_941111693 分钟前
C++中的枚举类高级用法
开发语言·c++·算法
chilavert3189 分钟前
技术演进中的开发沉思-191 JavaScript: 发展历程(上篇)
开发语言·javascript·ecmascript
jz_ddk26 分钟前
[算法] 算法PK:LMS与RLS的对比研究
人工智能·神经网络·算法·信号处理·lms·rls·自适应滤波
Miraitowa_cheems29 分钟前
LeetCode算法日记 - Day 106: 两个字符串的最小ASCII删除和
java·数据结构·算法·leetcode·深度优先
旭编29 分钟前
小红的好矩形
c++·算法
小白程序员成长日记30 分钟前
2025.11.12 力扣每日一题
算法·leetcode·职场和发展
Alex艾力的IT数字空间35 分钟前
设计既保持高性能又兼顾可移植性的跨平台数据结构
数据结构·分布式·算法·微服务·中间件·架构·动态规划
谅望者37 分钟前
数据分析笔记14:Python文件操作
大数据·数据库·笔记·python·数据挖掘·数据分析
l1t41 分钟前
调用python函数的不同方法效率对比测试
开发语言·数据库·python·sql·duckdb