PTA Python 代码问题:学生成绩分析代码为何无法通过所有测试点?

ID:20754 / 打印

pta python 代码问题:学生成绩分析代码为何无法通过所有测试点?

pta 上的 python 代码问题

一名开发者提供了以下代码,希望实现学生成绩分析的功能:

...

测试输入如下:

jack tom jim 95 84 32 90 75 45 85 90 67

然而,代码只通过了部分测试点。问题出在哪里呢?

立即学习“Python免费学习笔记(深入)”;

分析

该代码有两个主要问题:

  1. get_sum 方法中的分数累加错误:在 get_sum 方法中,self.sum_score 未初始化为 0,导致每次遍历都会累加前一次遍历的所有分数。正确的做法是每次遍历时计算该学生的总分并累加到 list_score1 列表中。
  2. list_score1 和 list_score2 指向同一列表:开发者创建了一个空列表 list_score2,并将其赋值给 list_score1。这导致这两个变量指向同一个列表对象。在对 list_score1 进行排序后,list_score2 的元素也会随之改变。解决方法是创建另一个列表对象,用于存储排序后的分数列表。

改进的代码

class Student:     sum_score = 0      def __init__(self, s_name, m_score, c_score, e_score):         self.s_name = s_name         self.m_score = m_score         self.c_score = c_score         self.e_score = e_score      def get_sum(self):         for i in range(len(self.s_name)):             self.sum_score += self.m_score[i] + self.c_score[i] + self.e_score[i]             list_score1.append(self.sum_score)      def get_best(self):         list_score2 = sorted(list_score1)         for k in range(len(list_score2)):             if list_score2[k] == list_score1[0]:                 best_name = self.s_name[k]                 print(f'{best_name} {self.m_score[k]} {self.c_score[k]} {self.e_score[k]}', end='')
上一篇: Scrapy 管道中连接数据库时出现`AttributeError: 'mysqlPipeline' object has no attribute 'opens_spider'`错误,如何解决?
下一篇: Qt Python 窗口鼠标移动时崩溃:为何会出现“Mwindow' object has no attribute 'mouse_x'”错误?

作者:admin @ 24资源网   2025-01-14

本站所有软件、源码、文章均有网友提供,如有侵权联系308410122@qq.com

与本文相关文章

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。