Решение номера 8023 ФИПИ

Муниципальный этап олимпиады по информатике проводился для учеников 7–11-х классов. Все ученики участвовали в общем конкурсе. Каждый участник олимпиады мог набрать от 0 до 400 баллов. По положению об олимпиаде победителем признаётся участник, набравший наибольшее количество баллов, при условии, что им набрано больше половины возможных баллов. Победителей может быть несколько, если это количество баллов наберут несколько человек; а может и не быть совсем, если никто не наберёт больше половины.

 

Напишите эффективную по времени работы и по используемой памяти программу (укажите используемую версию языка программирования, например BorlandPascal 7.0), которая будет определять фамилию и имя лучшего участника, не ставшего победителем олимпиады. Если следующий за баллом победителей один и тот же балл набрали несколько человек или если победителей нет, а лучших участников несколько (в этом случае они же являются искомыми), то должно выдаваться только число искомых участников. Гарантируется, что искомые участники (участник) имеются.

 

На вход программе сначала подаётся число участников олимпиады N (N<10000). В каждой из следующих N строк находится результат одного из участников олимпиады в следующем формате: <Фамилия> <Имя> <класс> <баллы>, где <Фамилия> – строка, состоящая не более чем из 20 непробельных символов; <Имя> – строка, состоящая не более чем из 15 непробельных символов; <класс> – число от 7 до 11; <баллы> – целое число от 0 до 400 набранных участником баллов. <Фамилия> и <Имя>, <Имя> и <класс>, а также <класс> и <баллы> разделены одним пробелом. Пример входной строки:

Иванов Пётр 10 275

Программа должна выводить через пробел Фамилию и Имя искомого участника или их число. Пример выходных данных:

Кузнецов Иван

Второй вариант выходных данных:

4

 

Объяснение

Для решения поставленной задачи, при вводе очередного значения будем выбирать и записывать имя и количество баллов. Сравниваем количество полученных баллов (point) с максимальным количеством (max_point). В конце цикла мы должны получить максимальные баллы (max_point), баллы лучшего участника (best_point), имя победителя (max_point_student), имя лучшего участника (best_point_student), количество победителей (max_point_student_count) и количество лучшего участника (best_point_student_count). Теперь, если максимальные баллы больше 200, то выводим best_point_student, если он один, или best_point_student_count, если несколько. Если же максимальные баллы меньше или равны 200, то победителей нет и нам нужно вывести max_point_student или max_point_student_count, в зависимости от количества участников, набравших этот балл.

 

Примеры входных данных

Первый пример входных данных:

4

Иванов Петя 10 125

Семенов Семен 8 108

Губанов Гена 9 100

Петров Алексей 9 166

 

Пример выходных данных:

Петров Алексей

 

 

Еще один пример входных данных:

6

Иванов Петя 10 125

Семенов Семен 8 280

Губанов Гена 9 210

Петров Алексей 9 106

Лягушкина Марина 10 210

Анюткина Аня 9 210

 

Пример выходных данных:

3

 

Решение на языке Pascal

Показать решение

 

Решение на языке Python

Показать решение

 

Похожие задачи: 8055

 

Оставить комментарий