Задача к ЕГЭ по информатике на тему «прочие прототипы» №2

Задание выполняется с использованием прилагаемых файлов

По итогам проведения олимпиады по программированию каждый участник получил определённое количество баллов. По регламенту олимпиады победителя присуждают K лучшим участникам, а призёра присуждают M лучшим участникам, следующим за ними. По заданной информации о результатах каждого из участников определите максимальный балл призёра и минимальный балл победителя данной олимпиады.

Входные и выходные данные.

В первой строке входного файла 26.txt находятся три числа, записанные через пробел: N  — общее количество результатов учащихся (натуральное число, не превышающее 10000  ), K  — количество победителей, M  — количество призёров. В следующих N  строках находятся значения каждого из результатов (все числа натуральные, не превышающие 10000  ), каждое в отдельной строке. Запишите в ответе два числа: сначала максимальный балл призёра, а затем минимальный балл победителя данной олимпиады.

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

6 2 3

7589

6344

8590

6231

3159

5462

При таких исходных данных ответ должен содержать 2  числа — 6344  и 7589  . Пояснение: победители набрали     7589  и 8590  балла, призёры набрали 6344  , 6231  , 5462  баллов. Тогда максимальный балл призёра 6344  , а минимальный балл победителя — 7589  .

Решение 1 ( Excel / LibreOffice):
Откроем текстовый документ, скопируем значения и перенесем их в Excel или LibreOffice.
Перенесём числовые значения общего количества результатов учащихся, количества победителей и призёров туда, где они нам не помешают. Сортируем по убыванию. Сначала выбираем первые 289 ячеек, соответствующих количеству победителей, выписываем последнее (минимальное) значение балла победителя, затем 691 ячейку, соответствующую количеству призёров, выписываем первое (максимальное) значение балла призёра. Выписанные значения и являются ответом.

Решение 2 (Python):

f = open(’Задание_26__ktct.txt’)
n, k, m = [int(s) for s in f.readline().split()]
a = sorted([int(s) for s in f], reverse=True)
ans1 = 0
ans2 = 10000000000000
for i in range(n):
    if i < k:
        ans2 = min(ans2, a[i])
    else:
        ans1 = max(ans1, a[i])
print(ans1, ans2)

Ответ: 9688 9688
Оцените статью
Я решу все!