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

Результаты олимпиады

14.04.2022, 21:03. Показов 3564. Ответов 2

Студворк — интернет-сервис помощи студентам
Помогите, пожалуйста, исправить код.

Во время проведения олимпиады каждый из участников получил свой идентификационный номер — натуральное число. Необходимо отсортировать список участников олимпиады по количеству набранных ими баллов от больших баллов к меньшим, а при равенстве баллов — по возрастанию идентификационных номеров. Встроенные алгоритмы сортировки не использовать.

Входные данные

На первой строке дано число N(1≤N≤1000) — количество участников. На каждой следующей строке даны идентификационный номер и набранное число баллов соответствующего участника. Все числа во входном файле не превышают 105.

Выходные данные

Выведите исходный список в порядке убывания баллов. Если у некоторых участников одинаковые баллы, то их между собой нужно выводить в порядке возрастания идентификационных номеров.

Примеры

Ввод

4
3 3
3 1
4 4
2 3

Вывод

4 4
2 3
3 3
3 1

Ввод

3
101 80
305 90
200 14

Вывод

305 90
101 80
200 14

Ввод

3
20 80
30 90
25 90

Вывод

25 90
30 90
20 80


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
def insertion_sort(ind, b):
    for i in range(1, len(b)):
        tmp = b[i]
        ix = ind[i]
        j = i - 1
        while j >= 0 and b[j] > tmp:
            b[j + 1] = b[j]
            ind[j + 1] = ind[j]
            j -= 1
        if b[j] == tmp:
            if ind[j] < ix:
                b[j], tmp = tmp, b[j]
                ind[j], ix = ix, ind[j]
        b[j + 1] = tmp
        ind[j + 1] = ix
 
 
n = int(input())
ind = []
b = []
for i in range(n):
    a, c = map(int, input(). split())
    ind.append(a)
    b.append(c)
insertion_sort(ind, b)
b.reverse()
ind.reverse()
for i in range(n):
    print(ind[i], b[i])
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.04.2022, 21:03
Ответы с готовыми решениями:

Результаты олимпиады
Результаты олимпиады Во время проведения олимпиады каждый из участников получил свой идентификационный номер — натуральное число....

Результаты олимпиады
Результаты олимпиады Во время проведения олимпиады каждый из участников получил свой идентификационный номер — натуральное число....

Подготовка олимпиады
Прямо сейчас жюри одного небезызвестного лагеря готовит контест. У них есть n задач, которые теперь надо отсортировать по возрастанию. Эту...

2
1 / 1 / 0
Регистрация: 05.02.2022
Сообщений: 5
14.04.2022, 21:13  [ТС]
shinzin, если бы я решила задачу, то не просила бы помощи. Мне выдаёт неправильный ответ при выполнении других тестов. Прежде чем обзываться, не зная человека и ситуации, лучше бы включили голову. Всего доброго!
1
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,707
14.04.2022, 22:33
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
n = int( input('n = ') )
lis = []
for i in range(n):
    val = tuple( map( int, input('-> ').split() ) )
    if not lis:
        lis.append(val)
    else:
        i   = 0
        key = lambda x:(-x[1], x[0])
        while i < len(lis) and key(val) > key(lis[i]):
            i += 1
        lis.insert(i, val)
for e in lis:
    print(*e)
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.04.2022, 22:33
Помогаю со студенческими работами здесь

Задача из олимпиады
Евгений — логист, и у него есть n товаров. За продажу i-го товара компания получит ai монет прибыли (она может быть и отрицательной). В...

Заключительный тур олимпиады
На финальный тур олимпиады прошло N участников, и всех их надо рассадить в две аудитории. Умная нейросеть проанализировала социальные...

Задача с олимпиады Сириус
Вы получили доступ к одной из камер наблюдения в особо секретной огранизации. В зоне видимости камеры находится табло, с которого вы...

Участники олимпиады и уникальные номера
N участников олимпиады получили уникальные номера от 1 до N. В результате решения задач на олимпиаде каждый участник получил некоторое...

Задача на строки из олимпиады МФТИ
В XVIII веке среди байтландских литераторов было популярно следующее развлечение: необходимо было написать литературный текст на заданную...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru