17.03 Прочие прототипы
Ошибка.
Попробуйте повторить позже
В файле содержится последовательность целых чисел. Элементы последовательности могут принимать целые положительные значения до 10 000 включительно. Необходимо найти минимальный чётный и минимальный нечётный элемент последовательности. Если минимальный чётный больше минимального нечётного, то программа должна вывести количество чётных, а также максимальный из них. В противном случае программа должна вывести количество нечётных, а также максимальный из них. Числа в ответе запишите через пробел.
Решение программой
Напишем программу, которая будет проходить по всем числам из файла и находить минимальные чётные и нечётные элементы, а также подсчитывать количество и максимумы для каждой из этих групп. Для этого создадим счётчики для количества чётных и нечётных чисел, переменные для минимальных и максимальных значений в каждой группе. Перебирая все числа, будем обновлять эти значения в зависимости от чётности числа. После прохода по списку сравним минимальный чётный и минимальный нечётный элементы. Если минимальный чётный больше минимального нечётного, то выведем количество чётных чисел и максимальное чётное число, иначе — количество нечётных чисел и максимальное нечётное число.
# считываем все числа из файла в список f = open("17_7.txt") a = [int(i) for i in f] # счётчики количества чётных и нечётных чисел cc = 0 # количество чётных cn = 0 # количество нечётных # переменные для минимальных значений — инициализируем большими числами mnc = 10**10 # минимальный чётный mnn = 10**10 # минимальный нечётный # переменные для максимальных значений — инициализируем маленькими числами mxc = -10**9 # максимальный чётный mxn = -10**9 # максимальный нечётный # перебираем все числа for i in range(len(a)): if a[i] % 2 == 0: # если число чётное, увеличиваем счётчик чётных, обновляем минимальный и максимальный чётные cc += 1 mnc = min(mnc, a[i]) mxc = max(mxc, a[i]) else: # если число нечётное, увеличиваем счётчик нечётных, обновляем минимальный и максимальный нечётные cn += 1 mnn = min(mnn, a[i]) mxn = max(mxn, a[i]) # сравниваем минимальные значения и выводим результат согласно условию if mnc > mnn: print(cc, mxc) else: print(cn, mxn)
Специальные программы

Программа
лояльности v2.0
Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!
Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.

Бесплатное онлайн-обучение
Для школьников из приграничных территорий России, проживающих в ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Курской, Брянской областях и Крыму.

Налоговые вычеты
Узнай, как получить налоговый вычет при оплате обучения в «Школково».

Специальное предложение
для учителей
Бесплатный доступ к любому курсу подготовки к ЕГЭ, ОГЭ и олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!

Вернём деньги за курс
за твою сотку на ЕГЭ
Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!