Тема 17. Обработка числовой последовательности

17.03 Прочие прототипы

Вспоминай формулы по каждой теме
Решай новые задачи каждый день
Вдумчиво разбирай решения
ШКОЛКОВО.
Готовиться с нами - ЛЕГКО!
Подтемы раздела обработка числовой последовательности
Решаем задачу:

Ошибка.
Попробуйте повторить позже

Задача 1#61227

В файле содержится последовательность целых чисел. Элементы последовательности могут принимать целые положительные значения до 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)

Ответ: 507 9842

Специальные программы

Все специальные программы

Программа
лояльности v2.0

Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!

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

Бесплатное онлайн-обучение

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

Налоговые вычеты

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

Специальное предложение
для учителей

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

Вернём деньги за курс
за твою сотку на ЕГЭ

Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!

cyberpunkMouse
cyberpunkMouse
Рулетка
Вы можете получить скидку в рулетке!