Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
1 / 1 / 0
Регистрация: 19.05.2020
Сообщений: 27

Ошибка тестов

14.07.2022, 20:45. Показов 779. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
у меня был код
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
from collections import namedtuple
 
 
def _quick_sort(array, low, high, comparator):
    if low < high:
        pivot = low
        for student in range(low + 1, high + 1):
            if comparator(array[low], array[student]):
                pivot += 1
                array[student], array[pivot] = array[pivot], array[student]
        array[pivot], array[low] = array[low], array[pivot]
        _quick_sort(array, low, pivot, comparator)
        _quick_sort(array, pivot + 1, high, comparator)
 
 
def quick_sort(array, comparator):
    _quick_sort(array, 0, len(array) - 1, comparator)
 
 
def comparator(member_first, member_second):
    if member_first.points < member_second.points:
        return True
    elif member_first.points > member_second.points:
        return False
    else:
        if member_first.penalties > member_second.penalties:
            return True
        elif member_first.penalties < member_second.penalties:
            return False
        else:
            if member_first.nickname > member_second.nickname:
                return True
            else:
                return False
 
 
if __name__ == '__main__':
    number_of_participants = int(input())
    students = [None] * number_of_participants
    Student = namedtuple('Student', 'nickname points penalties')
    for i in range(number_of_participants):
        try:
            nickname, points, penalties = input().split()
            students[i] = Student(nickname, int(points), int(penalties))
        except ValueError as error:
            raise ValueError(error)
    quick_sort(students, comparator)
    print('\n'.join(student.nickname for student in students))
Мне сказали, что def _quick_sort - лишняя функция - весь функционал можно сразу указать в quick_sort.

Я записала код так:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
from collections import namedtuple
 
 
def quick_sort(array, comparator, low=None, high=None):
    low = low or 0
    high = high or len(array) - 1
    if low < high:
        pivot = low
        for student in range(low + 1, high + 1):
            if comparator(array[low], array[student]):
                pivot += 1
                array[student], array[pivot] = array[pivot], array[student]
        array[pivot], array[low] = array[low], array[pivot]
        quick_sort(array, comparator, low=low, high=pivot)
        quick_sort(array, comparator, low=pivot + 1, high=high)
 
 
def comparator(member_first, member_second):
    if member_first.points < member_second.points:
        return True
    elif member_first.points > member_second.points:
        return False
    else:
        if member_first.penalties > member_second.penalties:
            return True
        elif member_first.penalties < member_second.penalties:
            return False
        else:
            if member_first.nickname > member_second.nickname:
                return True
            else:
                return False
 
 
if __name__ == '__main__':
    number_of_participants = int(input())
    students = [None] * number_of_participants
    Student = namedtuple('Student', 'nickname points penalties')
    for i in range(number_of_participants):
        try:
            nickname, points, penalties = input().split()
            students[i] = Student(nickname, int(points), int(penalties))
        except ValueError as error:
            raise ValueError(error)
    quick_sort(students, comparator)
    print('\n'.join(student.nickname for student in students))
Но появились ошибки:
Traceback (most recent call last):
File "394d83cb-692e-4d06-b747-465597d90f3f", line 45, in <module>
quick_sort(students, comparator)
File "394d83cb-692e-4d06-b747-465597d90f3f", line 14, in quick_sort
quick_sort(array, comparator, low=low, high=pivot)
File "394d83cb-692e-4d06-b747-465597d90f3f", line 14, in quick_sort
quick_sort(array, comparator, low=low, high=pivot)
File "394d83cb-692e-4d06-b747-465597d90f3f", line 14, in quick_sort
quick_sort(array, comparator, low=low, high=pivot)
[Previous line repeated 994 more times]
File "394d83cb-692e-4d06-b747-465597d90f3f", line 9, in quick_sort
for student in range(low + 1, high + 1):
RecursionError: maximum recursion depth exceeded in comparison


Я так понимаю, что достигнута максимальная глубина рекурсии, но как это можно исправить идей нет. Помогите это исправить
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.07.2022, 20:45
Ответы с готовыми решениями:

Не понимаю, каких тестов не хватает
Задание: Реализовать конечный автомат Мили в виде класса. Начальным состоянием автомата является A. Методы возвращают числовые...

Задача про количество сгенерированных тестов
Есть несколько сгенерированных тестов. Каждый тест представляет собой натуральное число, не меньшее m и не большее n (1&lt;=m,n&lt;=10^18)....

Ускорение unit-тестов
У меня есть проблема. Очень надеюсь, что есть человек, который с ситуацией сталкивался и знает решение. Я написал unittest...

5
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38171 / 21106 / 4307
Регистрация: 12.02.2012
Сообщений: 34,697
Записей в блоге: 14
15.07.2022, 07:35
Цитата Сообщение от Sop Посмотреть сообщение
у меня был код
- будем считать его правильным... (Писала не сама?)

Цитата Сообщение от Sop Посмотреть сообщение
Мне сказали, что def _quick_sort - лишняя функция - весь функционал можно сразу указать в quick_sort. Я записала код так:
- зачем было ломать работающий код? Написала ты заумно. Попробуй так.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
from collections import namedtuple
 
def quick_sort(array, comparator, low=0, high=len(array)-1):
    if low < high:
        pivot = low
        for student in range(low + 1, high + 1):
            if comparator(array[low], array[student]):
                pivot += 1
                array[student], array[pivot] = array[pivot], array[student]
        array[pivot], array[low] = array[low], array[pivot]
        quick_sort(array, comparator,low, pivot)
        quick_sort(array, comparator, pivot + 1, high)
 
 
def comparator(member_first, member_second):
    if member_first.points < member_second.points:
        return True
    elif member_first.points > member_second.points:
        return False
    else:
        if member_first.penalties > member_second.penalties:
            return True
        elif member_first.penalties < member_second.penalties:
            return False
        else:
            if member_first.nickname > member_second.nickname:
                return True
            else:
                return False
 
 
if __name__ == '__main__':
    number_of_participants = int(input())
    students = [None] * number_of_participants
    Student = namedtuple('Student', 'nickname points penalties')
    for i in range(number_of_participants):
        try:
            nickname, points, penalties = input().split()
            students[i] = Student(nickname, int(points), int(penalties))
        except ValueError as error:
            raise ValueError(error)
    quick_sort(students, comparator)
    print('\n'.join(student.nickname for student in students))
0
1 / 1 / 0
Регистрация: 19.05.2020
Сообщений: 27
15.07.2022, 09:24  [ТС]
Так получается такая ошибка:
Traceback (most recent call last):
File "be37f05d-7adf-4f41-ad84-6292bf13e722", line 3, in <module>
def quick_sort(array, comparator, low=0, high=len(array)-1):
NameError: name 'array' is not defined
1
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38171 / 21106 / 4307
Регистрация: 12.02.2012
Сообщений: 34,697
Записей в блоге: 14
15.07.2022, 12:07
Лучший ответ Сообщение было отмечено Sop как решение

Решение

Sop, да, это я ошибся.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
from collections import namedtuple
 
def quick_sort(array, comparator, low, high):
    if low < high:
        pivot = low
        for student in range(low + 1, high + 1):
            if comparator(array[low], array[student]):
                pivot += 1
                array[student], array[pivot] = array[pivot], array[student]
        array[pivot], array[low] = array[low], array[pivot]
        quick_sort(array, comparator,low, pivot)
        quick_sort(array, comparator, pivot + 1, high)
 
 
def comparator(member_first, member_second):
    if member_first.points < member_second.points:
        return True
    elif member_first.points > member_second.points:
        return False
    else:
        if member_first.penalties > member_second.penalties:
            return True
        elif member_first.penalties < member_second.penalties:
            return False
        else:
            if member_first.nickname > member_second.nickname:
                return True
            else:
                return False
 
 
if __name__ == '__main__':
    number_of_participants = int(input())
    students = [None] * number_of_participants
    Student = namedtuple('Student', 'nickname points penalties')
    for i in range(number_of_participants):
        try:
            nickname, points, penalties = input().split()
            students[i] = Student(nickname, int(points), int(penalties))
        except ValueError as error:
            raise ValueError(error)
    quick_sort(students, comparator,0,len(students)-1)
    print('\n'.join(student.nickname for student in students))
1
1 / 1 / 0
Регистрация: 19.05.2020
Сообщений: 27
15.07.2022, 14:26  [ТС]
Большое спасибо!
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
15.07.2022, 14:30
Sop,
Кликните здесь для просмотра всего текста
Цитата Сообщение от Sop Посмотреть сообщение
Большое спасибо!

1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.07.2022, 14:30
Помогаю со студенческими работами здесь

Написание unit тестов
Всем здравствуйте. Я новичок. Подскажите пожалуйста. Как протестировать функцию. Если в функции на input несколько входных...

Неоднократный запуск тестов
Добрый вечер! подскажите, пожалуйста. Я создала отдельный файл запуска тестов. test_classes_to_run = loader =...

Викторина: создание новых тестов
Нужно сделать викторину на python программа проверяет знания пользователя по определенной тематике или заранее подготовленному тесту . В...

Параметризация тестов с логическими операторами
Добрый день! Прошу помочь с пониманием вывода теста с применением параметризации, если на выходе указываем True или False... Есть...

Задача Мостики проходит 11 тестов из 18
Помогите, пожалуйста Задача №111970. Мостики В стране гномов очень много речек и озер, а сами гномы очень дружны и любят ходить друг к...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru