Тема 8. Комбинаторика

8.02 Подсчет количества слов/чисел

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

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

Задача 1#50790

Из букв Р,О,М,А,Н, составляются 7-буквенные последовательности. Сколько можно составить различных последовательностей, если известно, что в каждой из них на 2-ой позиции стоит буква А или Н, на 4-ой позиции не может стоять гласная буква, а на последнем месте стоит буква О? Каждая буква может встречается любое количество раз или не встречается совсем.

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

На первом, третьем, пятом и шестом месте может стоять 5 букв, никаких ограничений нет.

На втором месте может стоять одна из двух букв - А или Н, значит два варианта.

На четвертом месте может стоять только согласные буквы, их три - Р,М,Н.

На седьмом месте может стоять только одна буква - О.

Итого: 5 ⋅2⋅5⋅3 ⋅5⋅5⋅1 = 3750  последовательностей.

Решение программой (циклы):
Составим программу для перебора всех возможных 7-буквенных последовательностей из букв Р, О, М, А, Н. Для этого организуем 7 вложенных циклов, по одному на каждую букву. Каждый цикл перебирает буквы из строки "РОМАН формируя все возможные комбинации. После формирования каждого слова проверяем условия задачи, используя доступ к буквам по индексу.
Если последовательность удовлетворяет всем условиям, добавляем её в множество. После завершения циклов выводим длину множества, получая количество подходящих слов.

ans = set()  # множество для подходящих слов
alf = ’РОМАН’  # доступные буквы

# Перебор всех возможных 7-буквенных комбинаций
for x1 in alf:
    for x2 in alf:
        for x3 in alf:
            for x4 in alf:
                for x5 in alf:
                    for x6 in alf:
                        for x7 in alf:
                            w = x1 + x2 + x3 + x4 + x5 + x6 + x7
                            # проверяем условия на позиции 2, 4 и 7
                            if w[1] in ’АН’ and w[3] in ’РМН’ and w[-1] == ’О’:
                                ans.add(w)
print(len(ans))  # выводим количество неповторяющихся слов

Решение программой (itertools):
Для перебора всех возможных комбинаций символов используем функцию product из модуля itertools. Она формирует все последовательности указанной длины, позволяя включать буквы более одного раза или не включать вовсе.
Условия на позиции 2, 4 и 7 записываются аналогично решению с помощью циклов.

from itertools import product

ans = set()  # множество для хранения уникальных подходящих слов
alf = ’РОМАН’  # допустимые буквы

# Перебираем все возможные 7-буквенные комбинации из букв
for w in product(alf, repeat=7):
    w = ’’.join(w)  # преобразуем кортеж в строку
    # проверяем условия на позиции 2, 4 и 7
    if w[1] in ’АН’ and w[3] in ’РМН’ and w[-1] == ’О’:
        ans.add(w)  # добавляем последовательность в ответ
print(len(ans))  # выводим количество уникальных последовательностей

Ответ: 3750

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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