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

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

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

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

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

6 1 2

853

752

156

652

432

184

При таких исходных данных ответ должен содержать 551  . Пояснение: победитель набрал 853  балла, призёры набрали 752  и 652  баллов. Тогда взятые по модулю разность суммы баллов победителей и призёров равны: |853− 1404| = 551  .

Решение 1 ( Excel / LibreOffice):
Откроем текстовый документ, скопируем значения и перенесем их в Excel или LibreOffice.
Перенесём числовые значения общего количества результатов учащихся, количества победителей и призёров туда, где они нам не помешают. Сортируем по убыванию. Сначала выбираем первые 150 ячеек, соответствующих количеству победителей, считаем их сумму, затем 765 ячеек, соответствующих количеству призёров, определяем их сумму. Находим модуль разности полученных значений: |149659 — 748812| = 599153

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

f = open(’Задание_26__g57w.txt’)
n, k, m = map(int, f.readline().split())
a = []
for i in range(n):
    a.append(int(f.readline()))
a.sort(reverse=True)
ans1 = 0
for i in range(k):
    ans1 += a[i]
ans2 = 0
for i in range(k, k+m):
    ans2 += a[i]
print(abs(ans1-ans2))

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