нахождение минимума, максимума и среднего значения различных списков в 2D-матрице (двумерной) в python - PullRequest
0 голосов
/ 26 мая 2020

Я пытаюсь найти минимальное, максимальное и среднее значение для каждого ученика после (или внутри) матрицы. Как мне получить доступ к списку оценок каждого ученика в итерации l oop? Я начал с поиска минимума в функции (findlowest ()), но не могу понять, как получить за один раз только 1 студенческий экзамен.

studentExam = 5
minMaxScore = 5

def main():
    global studentName, studentExam, score, scoreList, examScoreMaxList, min, max


def ValidateUser(score):
    while score < 0 or score > 100:
        score = float(input("Invalid input, please try again"))
    return score


def getStudentInfo():
    studentName = int(input("enter the number of student: "))
    # studentExam = int(input("how many exam scores: "))
    # Initialize matrix
    matrix = []
    # For user input
    for i in range(studentName):  # A for loop for row entries
        scoreList = []
        scoreList.append(input("enter name of students " + str(i + 1) + ": "))

        for j in range(studentExam):  # A for loop for column entries

            score = float(input("enter exam " + str(j + 1) + ": "))
            score = ValidateUser(score)
            scoreList.append(score)
        matrix.append(scoreList)
    print(matrix)
    # for printing
    for i in range(studentName):
        for j in range(studentExam+1):
            print(matrix[i][j], end=" ")
        print()
getStudentInfo()


def findLowest():
    minlist = []
    min = minlist[0]
    for i in studentExam[0:5]:
        if i < min:
            min = i
    print("the minimum number is: ", min)

findLowest()

Я бы хотел, чтобы код отображался что-то похожее на следующее:

Mike H: min score - 78
        max score - 94
        avg score - 85

Sarah G: min score - 78
         max score - 94
         avg score - 85

Ответы [ 2 ]

0 голосов
/ 26 мая 2020

Смешивание разных типов данных в списке может сбивать с толку. Я держу их разделенными - имя студента - это ключ в словаре, список оценок - это значение. постоянные значения.

def getStudentInfo():
    studentName = int(input("enter the number of student: "))
    # studentExam = int(input("how many exam scores: "))
    # Initialize matrix
    matrix = {}
    # For user input
    for i in range(studentName):  # A for loop for row entries
        name = input("enter name of students " + str(i + 1) + ": ")
        matrix[name] = []

        for j in range(studentExam):  # A for loop for column entries
            score = float(input("enter exam " + str(j + 1) + ": "))
            score = ValidateUser(score)
            matrix[name].append(score)
    print(matrix)
    return matrix
data = getStudentInfo()

def findInfo(data, name = None):
    def findInfoByName(name):
        if name in data:
            scores = data[name]
            minScore = min(scores)
            maxScore = max(scores)
            avgScore = sum(scores) / len(scores)
            print(f"{name}:\tmin score - {minScore}")
            print(f"\tmax score - {maxScore}")
            print(f"\tavg score - {avgScore}")
    if name is None:
        for name in data:
            findInfoByName(name)
    else:
        findInfoByName(name)

findInfo(data)
0 голосов
/ 26 мая 2020

Это должно сработать. Вам просто нужен вложенный для l oop.

scores = [["Mike", 100, 98, 43, 56, 43], ["John", 95, 32, 79, 75, 67]]

for arr in scores:
    #arr = ["Mike", 100, 98, 43, 56, 43] or ["John", 95, 32, 79, 75, 67]
    min = None
    max = None
    sum = 0
    studentName = None
    for i in arr:
        if type(i) != str:
            if not min or i < min:
                min = i

            if not max or i > max:
                max = i

            sum += i
        else:
            studentName = i
    avg = sum/5

    print(studentName + ": \t min score - " + str(min))
    print("\t max score - " + str(max))
    print("\t avg score - " + str(avg))
    print()
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...